亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

golang - go-sql-driver/mysql for rows.Next()的性能問題

瀏覽:84日期:2022-06-19 15:34:09

問題描述

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結(jié)束:', goutil.GetCurrentTime())//延時關(guān)閉Rowsdefer 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}

問題解答

回答1:

可以用創(chuàng)建多個goroutine 分段查詢數(shù)據(jù)。使用channl在線程中拿去查詢結(jié)構(gòu)進行迭代。

回答2:

這不是golang性能的問題,其他編程語言也會類似。一次性去拿三萬條記錄本來就是個不合理的需求,應(yīng)該通過分頁來解決,一次只取幾十到幾百條。

相關(guān)文章:
主站蜘蛛池模板: 黄色片在线看 | 午夜性刺激免费视频观看不卡专区 | 国产一线视频在线观看高清 | 久久精品嫩草影院免费看 | 美国一级毛片片aa成人 | 黄色网页在线看 | 欧美一区中文字幕 | 日本一级特黄刺激爽大片 | 美女黄色三级 | 免费视频网站一级人爱视频 | 国内精品视频一区二区三区八戒 | 青青草国产三级精品三级 | 护士和黑人做爰 | 日韩精品午夜视频一区二区三区 | 看a级毛片| 欧美岛国| 久久人体视频 | 一级毛片黄片 | 亚洲第一区香蕉_国产a | 亚洲美女在线观看亚洲美女 | 亚洲第一免费视频 | 国产91精品露脸国语对白 | 精品国产品香蕉在线观看75 | 网站污污| 原味小视频在线www国产 | 久久草网站 | 2022在线精品视频网站 | 免费播放欧美毛片 | 九九热精| 免费网站www7788con | 亚洲精品九色在线网站 | 久久精品成人国产午夜 | 欧美日韩一区二区综合 | 国语对白清晰好大好白 | 亚洲天堂视频网 | 国产精品第1页在线播放 | 国产网红在线观看 | 亚洲高清在线观看看片 | 亚洲首页在线观看 | 精品日韩在线视频 | 麻豆影视网站 |