色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:100日期: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結束:', goutil.GetCurrentTime())//延時關閉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:

可以用創建多個goroutine 分段查詢數據。使用channl在線程中拿去查詢結構進行迭代。

回答2:

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

相關文章:
主站蜘蛛池模板: 国产精品外围在线观看 | 一区二区三区在线观看视频 | 国产夫妻视频 | 在线视频一二三区2021不卡 | 精品一区二区视频 | 午夜宅男宅女看在线观看 | 亚洲一区二区三区四区在线观看 | 国产一区二区fc2ppv在线播放 | 精品一久久香蕉国产二月 | 久久亚洲精品中文字幕亚瑟 | 自拍第1页 | 国产精品久久久久久免费播放 | 日本三级香港三级乳网址 | 欧美成人看片一区二区三区尤物 | 欧美日韩中文字幕在线观看 | 99青青| 日韩中文在线 | 国产一级a毛片高清 | 久草在线最新 | 欧美一区二区三区播放 | 欧美在线观看不卡 | fefe66免费毛片你懂的 | 成人午夜看片在线观看 | 国产精品99 | julia中文字幕久久亚洲 | ccav在线永久免费看 | 伊人久久精品午夜 | 男人的天堂网在线 | 国产成人a毛片在线 | 欧美变态一级毛片 | 精品一区二区三区四区在线 | 一区二区三区 亚洲区 | 午夜一级毛片不卡 | 国产中文字幕在线播放 | 亚洲一区二区在线免费观看 | 成人免费xxxxx在线视频 | 奇米网狠狠干 | 91精品专区| 久久频这里精品99香蕉久网址 | 99精品在线免费观看 | 一区二区三区欧美在线 |