[Go] golang连接查询mysql
发布时间:2021-05-21 06:46:17 所属栏目:大数据 来源: https://www.jb51.cc
导读:package mainimport ("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 :
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() } ?
(编辑:北几岛) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |