午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

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

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

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

相關文章:
主站蜘蛛池模板: 亚洲高清在线 | 欧美日韩成人一区 | 一区二区三区国产 | 国产精品精品久久久久久 | 污的视频在线观看 | 天堂网中文字幕 | 日韩激情视频在线观看 | 老牛嫩草二区三区观影体验 | 国内精品久久久久久久影视简单 | 日韩在线一区二区 | 成年人黄色在线观看 | 日本一区二区在线播放 | 国模精品视频一区二区 | 精品午夜久久 | 亚洲精品国产精品乱码不卡√香蕉 | 99久久国产视频 | 日韩一区二区三区在线播放 | 久久无| 中文字幕在线观看一区二区 | 欧美黄色短视频 | 欧美天堂视频 | 国产精品二区一区二区aⅴ污介绍 | 九九热这里只有精品6 | 日一区二区| 天天干免费视频 | 国产精品视频成人 | 欧洲天堂网 | 国产精品久久网 | 久久网站精品 | 亚洲成人少妇 | 有码在线播放 | 色综合婷婷 | 日韩精品片 | 中国a一片一级一片 | 黄色一级片视频 | 久久国产香蕉视频 | 色女视频 | 欧美精品另类 | 日本在线观看网址 | 日批在线看 | 日韩一区二区三 |