国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

相關文章:
主站蜘蛛池模板: www.亚洲天堂.com | 一级美女视频 | 国产精品人伦久久 | 18lxxlxx日本 | 真实国产精品视频国产网 | 最近最新中文字幕免费的一页 | 99国产精品一区二区 | 新久草视频 | 欧美久久久久欧美一区 | 日本欧美一区二区 | 免费观看日本视频 | 97在线免费视频 | 亚洲精品欧美精品 | 在线视频免费观看a毛片 | 99re热精品视频国产免费 | 亚洲精品一区最新 | 手机看片久久国产免费不卡 | 亚洲在线小视频 | 91热国产 | 国产高清在线精品一区 | 国产成人精品免费视频大全办公室 | 国产精品久久久久久小说 | 久久久精品久久久久三级 | 久草免费在线 | 欧美日韩精品一区二区在线线 | 亚洲一级免费毛片 | 一级片久久 | 成人精品国产亚洲 | 9丨精品国产高清自在线看 ⅹxx中国xxx人妖 | 国产成人精品一区二区免费视频 | 欧美一区二区三区精品国产 | 91看片淫黄大片欧美看国产片 | 欧美一级棒 | 美女扒开双腿让男人桶 | 久久99久久精品国产只有 | 91国在线啪精品一区 | 91久久国产综合精品女同我 | 欧洲美女与男人做爰 | 免费高清在线爱做视频 | 国产精品理论 | 日本黄色官网 |