在Go语言中实现并发查询数据库可以使用goroutine和channel来实现。以下是一个简单的示例代码: package main
在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来等待所有的查询操作完成,并在所有结果都被处理后关闭结果通道。然后遍历结果通道,输出查询结果。
这样我们就实现了并发查询数据库的功能。
--结束END--
本文标题: golang并发查询数据库怎么实现
本文链接: https://lsjlt.com/news/442826.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-04-05
2024-04-05
2024-04-05
2024-04-04
2024-04-05
2024-04-05
2024-04-05
2024-04-05
2024-04-04
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0