[Go] golang连接查询mysql
2023-02-18 15:41:16 时间
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() }
相关文章
- [Linux] Linux系统(进程管理)
- [Linux] Linux系统(用户管理)
- [Linux] Linux系统(文件操作)
- [Linux] Linux系统(登陆、退出、修密码)
- [javaSE] 看博客学习多线程的创建方式和优劣比较和PHP多线程
- [MongoDB] mongodb与php
- [MongoDB] MongoDB增删查改
- [Linux] Linux Shell查找文件
- [Linux] Linux的环境变量
- Git工作流中常见的三种分支策略:GitFlow、GitHubFlow和GitLabFlow
- 2022 IDE各种激活的,码上用起来吧 ,java、python、php、go等等
- Go语言实现的23种设计模式之结构型模式
- 快来,这里有23种设计模式的Go语言实现
- Golang container/ring 环形链表
- 基础架构之Gitlab Runner
- Red Hat Enterprise Linux 9.1镜像迁移到腾讯云操作说明
- GitOps实践之kubernetes部署Argocd
- 分布式版本控制系统Git的使用最全最细;
- C++ Primer Plus习题及答案-第十三章
- C++ Primer Plus习题及答案-第十四章