我同时在单独的 go 例程中运行 mysql “select” 查询。然而,mysql 服务似乎收集这些查询,按顺序(不是同时)运行它们,然后同时返回所有结果集,并且只有在所有查询都运行之后。
我的问题是:
1. 为什么这些查询按顺序运行而不是同时运行?
2. 为什么 mysql 等到所有查询都运行后再同时返回每个查询的结果集(即使每个结果集属于不同的 go routine 并且据说也使用单独的连接)?
另一件事:当我设置“SetMaxOpenConns(2)”时,它会同时返回两个结果集。如果设置为 3,则同时返回 3 个结果集。但是它们仍然总是按顺序运行。
有人知道这里发生了什么吗?
package main
import (
"database/sql"
"fmt"
"sync"
"time"
_ "github.com/go-sql-driver/mysql"
)
var database *sql.DB
func init() {
var err error
databaseURI := "root:toor@tcp(192.168.200.10:3306)/ahc"
database, err = sql.Open("mysql", databaseURI)
if err != nil {
fmt.Println(err)
} else {
fmt.Println("DB Connection Established")
//database.SetMaxIdleConns(0)
//database.SetMaxOpenConns(2)
}
}
func test(device string, wg *sync.WaitGroup) {
fmt.Println("Thread: " + device + " started")
start := time.Now()
var count string
//using go-sql-driver
sqlStatement, err := database.Prepare("select count(cpeName) from report where errMessage <> \"ok\" and cpeName = ? and jobID = ?")
if err != nil {
fmt.Println(err)
}
defer sqlStatement.Close()
err = sqlStatement.QueryRow(device, "11534").Scan(&count)
sqlStatement.Close()
duration := time.Since(start)
fmt.Println("Thread: " + device + " Duration: " + duration.String() + "\n")
wg.Done()
}
func main() {
var wg sync.WaitGroup
var deviceList = []string{"xx-swrk-ca-gen-s-002", "xx-leus-ca-ust-ap-068", "xx-sgvn-ca-lug-ap-004", "xx-swrk-ca-vez-s-005", "xx-swrk-ca-vez-ap-006", "xx-leus-ca-ust-ap-065", "xx-leus-ca-ust-ap-073", "xx-leus-ca-ust-ap-076", "xx-leus-ca-ust-ap-077", "xx-swrk-ca-gen-s-001"}
total := time.Now()
for _, device := range deviceList {
wg.Add(1)
go test(device, &wg)
}
wg.Wait()
duration := time.Since(total)
fmt.Println("\n\nTotal: Duration: " + duration.String() + "\n")
}
BIG阳
相关分类