今天我们使用gorm有某场景需要动态拼接sql语句,获取结果title为动态修改。

事情背景:

        此前我们使用beego开发使用beego自带orm,处理此类问题可定义接收变量为([]orm.Params)例如

var maps []orm.Params
if _, err := o.Raw(sql).Values(&maps);err!=nil {
    return    
}

         现在项目重构使用gin+gorm+redigo+iview结构

在处理此类问题时候发现gorm常用方法中并没有接收可变结果集的方法,经过重重困难终于找到可以使用scan方法解决此类问题,代码如下

	query := factory.DB()

	rows, _ := query.Raw(sql, endTime, endTime, endTime, startTime, startTime, endTime).Rows()
	cols, _ := rows.Columns()
	for rows.Next() {
		// Create a slice of interface{}'s to represent each column,
		// and a second slice to contain pointers to each item in the columns slice.
		columns := make([]interface{}, len(cols))
		columnPointers := make([]interface{}, len(cols))
		for i, _ := range columns {
			columnPointers[i] = &columns[i]
		}

		// Scan the result into the column pointers...
		if err := rows.Scan(columnPointers...); err != nil {
			return nil, err
		}

		// Create our map, and retrieve the value for each column from the pointers slice,
		// storing it in the map with the name of the column as the key.
		m := make(map[string]interface{})
		for i, colName := range cols {
			val := columnPointers[i].(*interface{})
			if colName == "time" {
				interfaceData := *val
				ba := []byte{}
				for _, b := range interfaceData.([]uint8) {
					ba = append(ba, byte(b))
				}
				m[colName] = string(ba)
			} else {
				m[colName] = *val
			}

		}

		// Outputs: map[columnName:value columnName2:value2 columnName3:value3 ...]
		chartList = append(chartList, m)
	}