golang - go-sql-driver/mysql for rows.Next()的性能問(wèn)題
問(wèn)題描述
1.當(dāng)查詢(xún)出來(lái)的記錄過(guò)萬(wàn)時(shí),遍歷Rows的時(shí)間過(guò)長(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}
問(wèn)題解答
回答1:可以用創(chuàng)建多個(gè)goroutine 分段查詢(xún)數(shù)據(jù)。使用channl在線(xiàn)程中拿去查詢(xún)結(jié)構(gòu)進(jìn)行迭代。
回答2:這不是golang性能的問(wèn)題,其他編程語(yǔ)言也會(huì)類(lèi)似。一次性去拿三萬(wàn)條記錄本來(lái)就是個(gè)不合理的需求,應(yīng)該通過(guò)分頁(yè)來(lái)解決,一次只取幾十到幾百條。
相關(guān)文章:
1. javascript - 這不是對(duì)象字面量函數(shù)嗎?為什么要new初始化?2. sql語(yǔ)句 - mysql中關(guān)聯(lián)表查詢(xún)問(wèn)題3. javascript - 如何將一個(gè)div始終固定在某個(gè)位置;無(wú)論屏幕和分辨率怎么變化;div位置始終不變4. html5 - 有可以一次性把所有 css外部樣式轉(zhuǎn)為html標(biāo)簽內(nèi)style=" "的方法嗎?5. javascript - vscode alt+shift+f 格式化js代碼,通不過(guò)eslint的代碼風(fēng)格檢查怎么辦。。。6. html - vue項(xiàng)目中用到了elementUI問(wèn)題7. javascript - 有什么比較好的網(wǎng)頁(yè)版shell前端組件?8. javascript - iframe 為什么加載網(wǎng)頁(yè)的時(shí)候滾動(dòng)條這樣顯示?9. javascript - [js]為什么畫(huà)布里不出現(xiàn)圖片呢?在線(xiàn)等10. javascript - 原生canvas中如何獲取到觸摸事件的canvas內(nèi)坐標(biāo)?
