golang并发查询数据库怎么实现

avatar
作者
猴君
阅读量: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来等待所有的查询操作完成,并在所有结果都被处理后关闭结果通道。然后遍历结果通道,输出查询结果。

这样我们就实现了并发查询数据库的功能。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!