golang mysql并发查询_[Go] golang连接查询mysql

package main

import (

"database/sql"

_ "github.com/go-sql-driver/MysqL"

"log"

)

func main() {

//连接数据库查询

db,err := sql.Open("MysqL","root:xxx@tcp(xxx:3306)/my_test")

if err != nil {

log.Fatal(err.Error())

}

//最终关闭数据库

defer db.Close()

msql := "select * from user"

rows,err := db.Query(msql)

if err != nil {

log.Fatal(err.Error())

}

//获取列名

columns,_ := rows.Columns()

//定义一个切片,长度是字段的个数,切片里面的元素类型是sql.RawBytes

values := make([]sql.RawBytes,len(columns))

//定义一个切片,元素类型是interface{} 接口

scanArgs := make([]interface{},len(values))

for i := range values {

//把sql.RawBytes类型的地址存进去了

scanArgs[i] = &values[i]

}

//获取字段值

var result []map[string]string

for rows.Next() {

res := make(map[string]string)

rows.Scan(scanArgs...)

for i,col := range values {

res[columns[i]] = string(col)

}

result = append(result,res)

}

//遍历结果

for _,r := range result {

for k,v := range r {

log.Printf("%s==%s",k,v)

}

}

rows.Close()

}

a57c1a4cb5b038d19a14dadbee3182b5.png

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

如您喜欢交流学习经验,点击链接加入交流1群:1065694478(已满)交流2群:163560250


版权声明:本文为weixin_42099942原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。