国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

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

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

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

問(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)文章:
主站蜘蛛池模板: 桦川县| 大兴区| 阳西县| 克东县| 昌平区| 孟津县| 兰溪市| 霍林郭勒市| 湖北省| 南开区| 清流县| 开平市| 石楼县| 阳高县| 兴业县| 桑植县| 肃宁县| 绍兴市| 中江县| 大庆市| 开远市| 鱼台县| 抚顺县| 德钦县| 望都县| 东海县| 开江县| 邹城市| 莆田市| 抚远县| 永胜县| 万盛区| 柳州市| 廊坊市| 故城县| 宁蒗| 高州市| 林口县| 岐山县| 南岸区| 延寿县|