[Go] golang连接查询mysql

本文介绍了一个使用Go语言连接并查询MySQL数据库的具体示例,包括数据库连接、执行SQL查询、获取列名及字段值的过程,展示了如何将查询结果转化为map结构进行处理。
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()
}

 

  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值