阅读量:0
在Go语言中实现并发查询数据库可以使用goroutine和channel来实现。以下是一个简单的示例代码:
package main import ( "database/sql" "fmt" "log" "sync" _ "github.com/go-sql-driver/mysql" ) type Result struct { ID int Name string } func dbQuery(db *sql.DB, query string, resultChan chan<- Result, wg *sync.WaitGroup) { defer wg.Done() rows, err := db.Query(query) if err != nil { log.Printf("Error executing query: %s\n", err) return } defer rows.Close() for rows.Next() { var result Result err := rows.Scan(&result.ID, &result.Name) if err != nil { log.Printf("Error scanning result: %s\n", err) return } resultChan <- result } } func main() { db, err := sql.Open("mysql", "user:password@tcp(localhost:3306)/database") if err != nil { log.Fatalf("Error connecting to database: %s\n", err) } defer db.Close() queries := []string{"SELECT id, name FROM table1", "SELECT id, name FROM table2"} resultChan := make(chan Result) var wg sync.WaitGroup for _, query := range queries { wg.Add(1) go dbQuery(db, query, resultChan, &wg) } go func() { wg.Wait() close(resultChan) }() for result := range resultChan { fmt.Printf("ID: %d, Name: %s\n", result.ID, result.Name) } }
上述代码中,我们首先建立数据库连接,然后定义一个Query函数,该函数接受一个SQL查询语句和一个结果通道,通过查询语句从数据库中获取数据,并将结果发送到结果通道中。
在主函数中,我们定义了一个查询语句的切片,然后创建了一个结果通道和一个等待组。接着,我们遍历查询语句切片,为每个查询语句启动一个goroutine来执行查询操作。在goroutine中,我们调用Query函数来执行数据库查询,并将结果发送到结果通道中。
最后,我们在主函数中启动一个goroutine来等待所有的查询操作完成,并在所有结果都被处理后关闭结果通道。然后遍历结果通道,输出查询结果。
这样我们就实现了并发查询数据库的功能。