go数据库操作
go数据库操作
下载数据库驱动
比如要使用MYSQL,就要下载MYSQL驱动:go get github.com/go-sql-driver/mysql
连接数据库
连接数据的DSN格式为: username:password@protocol(address)/dbname?param=value
1 2 3 4 5 6 | db, err := sql.Open( "mysql" , "root:root@tcp(127.0.0.1:3306)/test?charset=utf8" ) if err != nil { fmt.Println( "failed to open database:" , err.Error()) return } defer db.Close() |
返回的DB对象,实际封装了一个数据库连接池,对于goroutine是线程安全的,可以放心使用。这个数据库连接池由"database/sql"包负责自动创建和回收。连接池的大小可以由SetMaxIdleConns指定。
需要注意的是,创建DB对象成功,并不代表已经成功的连接了数据库,数据库连接只有在真正需要的时候才会被创建。
关闭数据库
defer db.Close()
CRUD
DB中执行SQL通过Exec和Query方法,查询操作是通过Query完成,它会返回一个sql.Rows的结果集,包含一个游标用来遍历查询结果;Exec方法返回的是sql.Result对象,用于检测操作结果,及被影响记录数。
查询
1 2 3 4 5 6 7 8 9 10 11 | rows, err := db.Query( "SELECT * FROM user" ) if err != nil { fmt.Println( "fetech data failed:" , err.Error()) return } defer rows.Close() for rows.Next() { var uid int var name, password string rows.Scan(&uid, &name, &password) fmt.Println( "uid:" , uid, "name:" , name, "password:" , password) |
新增
1 2 3 4 5 6 7 8 9 10 11 | result, err := db.Exec( "INSERT INTO user(name,password) VALUES('tom', 'tom')" ) if err != nil { fmt.Println( "insert data failed:" , err.Error()) return } id, err := result.LastInsertId() if err != nil { fmt.Println( "fetch last insert id failed:" , err.Error()) return } fmt.Println( "insert new record" , id) |
修改
1 2 3 4 5 6 7 8 9 10 11 | result, err = db.Exec( "UPDATE user SET password=? WHERE name=?" , "tom_new_password" , "tom" ) if err != nil { fmt.Println( "update data failed:" , err.Error()) return } num, err := result.RowsAffected() if err != nil { fmt.Println( "fetch row affected failed:" , err.Error()) return } fmt.Println( "update recors number" , num) |
删除
1 2 3 4 5 6 7 8 9 10 11 | result, err = db.Exec( "DELETE FROM user WHERE name=?" , "tom" ) if err != nil { fmt.Println( "delete data failed:" , err.Error()) return } num, err = result.RowsAffected() if err != nil { fmt.Println( "fetch row affected failed:" , err.Error()) return } fmt.Println( "delete record number" , num) |
事务控制
sql.Tx用来支持事务处理
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | tx, err := db.Begin() result, err = tx.Exec( "DELETE FROM order WHERE uid=? " , 2) if err != nil { fmt.Println( "delete data failed:" , err.Error()) return } num, err = result.RowsAffected() if err != nil { fmt.Println( "fetch row affected failed:" , err.Error()) return } fmt.Println( "delete record number" , num) result, err = tx.Exec( "DELETE FROM user WHERE uid=? " , 2) if err != nil { fmt.Println( "delete data failed:" , err.Error()) return } num, err = result.RowsAffected() if err != nil { fmt.Println( "fetch row affected failed:" , err.Error()) return } fmt.Println( "delete record number" , num) // 根据条件回滚或者提交 // tx.Rollback() tx.Commit() |
预备表达式
sql.Stmt支持预备表达式,可以用来优化SQL查询提高性能,减少SQL注入的风险, DB.Prepare()和Tx.Prepare()都提供了对于预备表达式的支持。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | stmt, err := db.Prepare( "DELETE FROM order WHERE oid=?" ) if err != nil { fmt.Println( "fetch row affected failed:" , err.Error()) return } result, err = stmt.Exec(1) if err != nil { fmt.Println( "delete data failed:" , err.Error()) return } num, err = result.RowsAffected() if err != nil { fmt.Println( "fetch row affected failed:" , err.Error()) return } fmt.Println( "delete record number" , num) |
注意点
每次db.Query()操作后,都建议调用rows.Close()
本文来自博客园,作者:{咏南中间件},转载请注明原文链接:https://www.cnblogs.com/hnxxcxg/p/15236595.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
2020-09-07 mormot2对bson的封装
2020-09-07 bson
2017-09-07 centos7安装MYSQL
2015-09-07 咏南多层开发框架支持最新的DELPHI 10 SEATTLE
2012-09-07 xe2 datasnap中间层+d7客户端调用