加入收藏 | 设为首页 | 会员中心 | 我要投稿 北几岛 (https://www.beijidao.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

[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()
}

?

  

(编辑:北几岛)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读