av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

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

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

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

相關文章:
主站蜘蛛池模板: av网站免费在线观看 | 久久一区精品 | 亚洲在线免费观看 | 久草视频免费看 | 134vcc影院免费观看 | 欧美日韩色 | 911亚洲精品 | 国产黄色片视频 | 日韩视频第一页 | 亚洲国产一区在线观看 | 日韩成人免费 | 欧美日韩一本 | 成人毛片在线观看 | 成人在线视频网站 | 成人在线视频免费 | 日韩一区二区三区四区 | 欧美日韩一区二区三区视频 | 五月天堂网| 日韩成人三级 | 一区视频在线 | 97视频在线播放 | 一区二区三区在线看 | 天天干夜夜艹 | 欧美一级欧美三级在线观看 | a级片免费观看 | av免费网站 | 欧美日韩国| 99视频在线播放 | 久久久久久久97 | a视频在线免费观看 | 国产成人区 | 亚洲欧美精品一区二区 | 又大又黄又爽 | 欧美一区二区在线视频 | 婷婷六月激情 | 黄色大毛片 | 中文字幕一级片 | 欧美一级二级三级 | www.chengren| 欧美啪啪网 | 一级片免费 |