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

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:108日期:2022-06-19 15:34:09

問題描述

1.當(dāng)查詢出來的記錄過萬時(shí),遍歷Rows的時(shí)間過長(zhǎng),達(dá)到1分鐘甚至更多

程序代碼:

rows, err := p.conn.Query(sqlStr, params...)if err != nil { log.Println('mysql query error', err.Error()) return nil, err}log.Println('conn結(jié)束:', goutil.GetCurrentTime())//延時(shí)關(guān)閉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記錄的時(shí)候,長(zhǎng)達(dá)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)建多個(gè)goroutine 分段查詢數(shù)據(jù)。使用channl在線程中拿去查詢結(jié)構(gòu)進(jìn)行迭代。

回答2:

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

相關(guān)文章:
主站蜘蛛池模板: 成人黄色视屏 | 国产一级aa大片毛片 | 国产乱理伦片a级在线观看 国产乱理伦片在线观看 | 久久97精品久久久久久清纯 | 久久精品一级 | 国产乱码精品一区二区三 | 亚洲狠狠网站色噜噜 | 国产黄色在线看 | 日韩在线看片中文字幕不卡 | 国产麻豆网站 | 国内精品福利视频 | 把女人弄爽特黄aa大片视频 | 日本高清色本免费现在观看 | 黄色一级片免费在线观看 | 国产免费高清mv视频在线观看 | 日韩一区二区三区在线 | 免费看黄网站大全 | 久久这里只有精品免费看青草 | 精品综合久久久久久8888 | 国产日韩一区 | 国产日韩欧美精品一区 | 国产一区二区在线观看麻豆 | 青青伊人91久久福利精品 | 青青草91在线| 午夜黄| 国产精品自拍视频 | 欧洲视频一区 | 极品美女一级毛片 | 欧美激情艳三级 | 日本老妇人乱视频 | 婷婷涩涩| 91国内精品线免费播放 | 欧美另类网 | 欧美毛片一级的免费的 | 亚洲激情中文字幕 | 国产无圣光高清一区二区 | 国产一级视频播放 | 91性视频| 我要看黄色一级大片 | 特级一级毛片 | 欧美在线一级毛片视频 |