[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() }
十年开发经验程序员,离职全心创业中,历时三年开发出的产品《唯一客服系统》
一款基于Golang+Vue开发的在线客服系统,软件著作权编号:2021SR1462600。一套可私有化部署的网站在线客服系统,编译后的二进制文件可直接使用无需搭开发环境,下载zip解压即可,仅依赖MySQL数据库,是一个开箱即用的全渠道在线客服系统,致力于帮助广大开发者/公司快速部署整合私有化客服功能。
开源地址:唯一客服(开源学习版)
官网地址:唯一客服官网