亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

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

瀏覽:87日期: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:

可以用創(chuàng)建多個goroutine 分段查詢數(shù)據(jù)。使用channl在線程中拿去查詢結構進行迭代。

回答2:

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

相關文章:
主站蜘蛛池模板: 91精品国产人成网站 | 小蝌蚪亚洲精品国产 | 国产精品1区 | 日韩激情在线 | 麻豆视频网 | 国内精品久久久久鸭 | 国产成人精品三区 | 国产女人一区二区 | 亚洲综合17p | 国产成人青青热久免费精品 | 国产成人h综合亚洲欧美在线 | 黄色网络在线观看 | 欧美在线免费观看 | 成人久久18免费网址 | 黑人草逼视频 | 丝袜超薄交口足456免费视频 | 精品欧美日韩一区二区 | 91成人免费福利网站在线 | 久久午夜羞羞影院免费观看 | 日韩黑寡妇一级毛片国语对白 | 欧美一级三级 | 二级黄绝大片中国免费视频0 | 欧美最新一区二区三区四区 | 亚洲黄色免费网址 | 自拍视频网 | 成人亚洲综合 | 欧美三级在线免费观看 | 色婷婷777| 国产成人精品综合在线观看 | 一区二区免费 | jk美女伸开两腿让我爽视频 | 91福利国产在线观一区二区 | 欧美一级毛片欧美毛片视频 | 91高清免费视频 | 久久精品国产400部免费看 | 国产福利写真视频在线观看 | 国产成人精品在线观看 | 国产一区在线看 | 特级一级毛片视频免费观看 | 草草视频在线免费观看 | 欧美精品久久久亚洲 |