go-sql-driver/mysql for rows.Next()的性能问题
1.当查询出来的记录过万时,遍历Rows的时间过长,达到1分钟甚至更多
程序代码:
rows, err := p.conn.Query(sqlStr, params...)
if err != nil {
log.Println("mysql query error", err.Error())
return nil, err
}
log.Println("conn结束:", goutil.GetCurrentTime())
//延时关闭Rows
defer rows.Close()
//获取记录列
if columns, err := rows.Columns(); err != nil {
return nil, err
} else {
//拼接记录Map
values := make([]sql.RawBytes, len(columns))
scans := make([]interface{}, len(columns))
for i := range values {
scans[i] = &values[i]
}
//此处遍历在3W记录的时候,长达1分钟甚至更多
for rows.Next() {
_ = rows.Scan(scans...)
each := map[string]interface{}{}
for i, col := range values {
each[columns[i]] = string(col)
}
rowMaps = append(rowMaps, each)
}
return rowMaps, nil
}
相关阅读:
node模块与es6模块的区别
c++面向对象怎么学?
python有哪些提取文本摘要的库?
gearman -d后netstat -apn一直检测不到4730端口被监听啊!!
macport 安装php55 后如何编译PHP 安装其他插件?
在设置完flask环境后总是出现这样的错误ImportError: No module named flask
http网络请求,小知识点
typecho国内无法使用Gravatar
c++ 类成员的访问控制是怎么实现的?
Mysql查询问题
Yii2中做中英文网站
安装Cocoapods, 更新gem出现的问题。
js获取不到地理位置
怎样把从服务器获取的日期转换成年月日的形式
如何使用ffmpeg把wmv转换为ts
java在线程同步块中修改同步对象会有什么后果?
求搜狐微博php sdk还有豆瓣的!
Java收到iOS的系统表情之后,iOS客户端请求之后显示为“?”
可汗学院的数学的知识地图是如何实现的?
有谁有使用HTML5 Canvas 实现蜡笔或者粉笔效果画笔的经验