亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

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

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

瀏覽:114日期: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性能的問題,其他編程語言也會類似。一次性去拿三萬條記錄本來就是個不合理的需求,應該通過分頁來解決,一次只取幾十到幾百條。

相關文章:
主站蜘蛛池模板: 中文字幕日韩一区二区不卡 | 成人免费ā片 | 一级黄色美女视频 | 亚州久久| 欧美性色生活片免费播放 | 国产一区二区久久精品 | 国产毛片a精品毛 | 中文字幕在线观看国产 | dy888午夜国产午夜精品 | 88av视频在线观看 | 99精品一区二区免费视频 | 最新国产精品好看的国产精品 | 在线观看欧美亚洲日本专区 | 影院成人区精品一区二区婷婷丽春院影视 | 久久免费看视频 | 114毛片免费观看网站 | 亚洲美女网址 | 国产精品久久毛片 | 亚洲成a人片在线观 | 日韩一区二区三区在线免费观看 | 久久精品中文字幕首页 | 免费在线黄色网址 | 91精品久久久久亚洲国产 | 欧美一区二区三区不卡 | 一级毛片成人免费看a | 亚洲国产精品欧美日韩一区二区 | 日韩一级影片 | 亚洲一区二区三区高清网 | 性做久久久久免费观看 | 日本高清专区一区二无线 | 精品国产三级在线观看 | 久久久久国产精品免费网站 | jyzzjyzzjyzz日本在线观看 | 久久综合久久美利坚合众国 | 精品国产成人高清在线 | 伊人久久精品午夜 | 国产亚洲精品xxx | 久久一级黄色片 | 免费又黄又爽视频 | 久久免费播放 | 国内精品视频九九九九 |