脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Golang - Go语言增强版操作MySQL(SQLX)

Go语言增强版操作MySQL(SQLX)

2021-01-28 01:13Go语言进阶学习Go进阶者 Golang

上次咱们学习了如何使用Go操作Mysql,并且实现了简单的增删改查。但是相对来说,还有有点复杂的,可能那些大佬也都觉得繁琐叭。就又开发出了增强版查询Mysql操作库Sqlx。

Go语言增强版操作MySQL(SQLX)

前言

上次咱们学习了如何使用Go操作Mysql,并且实现了简单的增删改查。

但是相对来说,还有有点复杂的,可能那些大佬也都觉得繁琐叭。

就又开发出了增强版查询Mysql操作库Sqlx。

mod文件

go.mod

  1. module sqlxDemo 
  2.  
  3. go 1.14 
  4.  
  5. require ( 
  6.     github.com/go-sql-driver/mysql v1.4.0 
  7.     github.com/jmoiron/sqlx v1.2.0 
  8.     google.golang.org/appengine v1.6.7 // indirect 

创建数据表

创建表代码

  1. CREATE TABLE `userinfo` ( 
  2.   `id` int(11) NOT NULL AUTO_INCREMENT, 
  3.   `namevarchar(10) DEFAULT NULL, 
  4.   `phone` char(11) DEFAULT NULL, 
  5.   `address` varchar(64) DEFAULT NULL, 
  6.   PRIMARY KEY (`id`) 
  7. ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4; 

创建结构体

结构体代码

  1. type Userinfo struct { 
  2.     Id      int64  `json:"id"
  3.     Name    string `json:"name"
  4.     Phone   string `json:"phone"
  5.     Address string `json:"address"

连接数据库

代码

  1. import ( 
  2.     "fmt" 
  3.     _ "github.com/go-sql-driver/mysql" 
  4.     "github.com/jmoiron/sqlx" 
  5. type Userinfo struct { 
  6.     Id      int64  `json:"id"
  7.     Name    string `json:"name"
  8.     Phone   string `json:"phone"
  9.     Address string `json:"address"
  10. func main() { 
  11.     dsn := "root:rootroot@tcp(127.0.0.1:3306)/go_mysql_demo?charset=utf8mb4&parseTime=True" 
  12.     // 使用 MustConnect 连接的话,验证失败不成功直接panic 
  13.     //db := sqlx.MustConnect("mysql", dsn) 
  14.  
  15.     //使用 Connect 连接,会验证是否连接成功, 
  16.     db, err := sqlx.Connect("mysql", dsn) 
  17.  
  18.     if err != nil { 
  19.         fmt.Printf("connect DB failed, err:%v\n", err) 
  20.         return 
  21.     db.SetMaxOpenConns(20) 
  22.     db.SetMaxIdleConns(10) 

查询单条

我记得使用原来的方式进行查询并且绑定结构体,是这审的。

  1. //查询单条 
  2. sqlStr := "SELECT id,`name`,phone,address from userinfo where id = ?;" 
  3. var user Userinfo 
  4. err = db.QueryRow(sqlStr, 1).Scan(&user.Id, &user.Name, &user.Phone, &user.Address) 
  5. if err != nil { 
  6.     fmt.Println("查询失败", err) 
  7.     return 

看第4行代码,需要将结构体的字段一个一个点上去。

如果使用sqlx呢?

代码

  1. //查询 
  2. sqlStr := "SELECT id,`name`,phone,address from userinfo where id = ?;" 
  3. var user Userinfo 
  4. err = db.Get(&user, sqlStr, 1) 
  5. if err != nil { 
  6.     fmt.Println("查询失败:", err) 
  7.     return 
  8. fmt.Println("user:"user

执行结果

Go语言增强版操作MySQL(SQLX)

还是第4行代码,直接一个结构体扔过去,就绑定成功了。

如果表有很多字段,结构体字段也有很多,这个是很有用的。

查询多条

还是惯例,看看原来是怎么查的。

  1. //查询多条 
  2. sqlStr := "SELECT id,`name`,phone,address from userinfo where id >= ?" 
  3. //参数同 QueryRow 
  4. rows, err := db.Query(sqlStr, 1) 
  5. //处理err 
  6. // 此处使用rows释放所有链接 
  7. defer rows.Close() 
  8. //循环整理所有数据 
  9. var userList = make([]Userinfo, 0, 10) 
  10. for rows.Next() { 
  11.     var user Userinfo 
  12.     err = rows.Scan(&user.Id, &user.Name, &user.Phone, &user.Address) 
  13.     //处理err 
  14.     userList = append(userList, user
  15. fmt.Println(userList) 

为了方便,我去掉了err,使用伪代码处理err代替。

原来的方法,查询出来还得需要一个循环,还需要一个切片,乖乖嘞,打扰了。

来看看sqlx

代码

  1. //查询多条 
  2. sqlStr := "SELECT id,`name`,phone,address from userinfo where id >= ?" 
  3. var userList []Userinfo 
  4. err = db.Select(&userList, sqlStr, 1) 
  5. if err != nil { 
  6.     fmt.Println("查询失败:", err) 
  7.     return 
  8. fmt.Println("userList:",userList) 

执行结果

Go语言增强版操作MySQL(SQLX)

还是直接扔过去,就绑定完成了,真是美滋滋。

添加

额,添加,更新,删除,事物的话,似乎跟原来差不多,直接看代码叭。

代码

  1. //添加 
  2. sqlStr := "INSERT into userinfo(name,phone,address) values(?,?,?);" 
  3. result, err := db.Exec(sqlStr, "吴彦祖", 555, "不知道哪的"
  4. if err != nil { 
  5.     fmt.Println("插入失败", err) 
  6.     return 
  7. row_affect, err := result.RowsAffected() 
  8. if err != nil { 
  9.     fmt.Println("受影响行数获取失败:", err) 
  10.     return 
  11. fmt.Println("受影响的行数:", row_affect) 
  12. lastId, err := result.LastInsertId() 
  13. if err != nil { 
  14.     fmt.Println("新增行id获取失败:", err) 
  15.     return 
  16. fmt.Println("新增行id:", lastId) 
  17. fmt.Println("插入成功"

执行结果

Go语言增强版操作MySQL(SQLX)

Mysql

Go语言增强版操作MySQL(SQLX)

更新

代码

  1. //更新数据 
  2. sqlStr := `UPDATE userinfo set name=? where id=?;` 
  3. result, err := db.Exec(sqlStr, "吴彦祖666", 4) 
  4. if err != nil { 
  5.     fmt.Println("更新失败", err) 
  6.     return 
  7. //受影响的行数 
  8. row_affect, err := result.RowsAffected() 
  9. if err != nil { 
  10.     fmt.Println("受影响行数获取失败:", err) 
  11.     return 
  12. fmt.Println("受影响的行数:", row_affect) 
  13.  
  14. fmt.Println("更新成功"

执行结果

Go语言增强版操作MySQL(SQLX)

Mysql

Go语言增强版操作MySQL(SQLX)

删除

代码

  1. sqlStr := "delete from userinfo where id = ?;" 
  2. result, err := db.Exec(sqlStr, 4) 
  3. if err != nil { 
  4.     fmt.Println("删除失败", err) 
  5.     return 
  6. //受影响的行数 
  7. row_affect, err := result.RowsAffected() 
  8. if err != nil { 
  9.     fmt.Println("受影响行数获取失败:", err) 
  10.     return 
  11. fmt.Println("受影响的行数:", row_affect) 
  12.  
  13. fmt.Println("删除成功"

执行结果

Go语言增强版操作MySQL(SQLX)

Mysql

Go语言增强版操作MySQL(SQLX)

事物

代码

  1. //事物 
  2. tx, err := db.Begin() 
  3. if err != nil { 
  4.     //释放事物 
  5.     if tx != nil { 
  6.         tx.Rollback() 
  7.     fmt.Println("事物开启失败"
  8.     return 
  9. 张三减10块Sql := `UPDATE bill set money=money - 10 where name = ?;` 
  10. result, err := tx.Exec(张三减10块Sql, "张三"
  11. if err != nil { 
  12.     //有错误表示更是失败,回滚原来状态 
  13.     tx.Rollback() 
  14.     fmt.Println(err) 
  15.     return 
  16. 张三受影响行数, err := result.RowsAffected() 
  17. if err != nil { 
  18.     tx.Rollback() // 回滚 
  19.     return 
  20.  
  21. 李四加10块Sql := `UPDATE bill set money=money + 10 where name = ?;` 
  22. result, err = tx.Exec(李四加10块Sql, "李四"
  23. if err != nil { 
  24.     //有错误表示更是失败,回滚原来状态 
  25.     tx.Rollback() 
  26.     fmt.Println(err) 
  27.     return 
  28. 李四受影响行数, err := result.RowsAffected() 
  29. if err != nil { 
  30.     tx.Rollback() // 回滚 
  31.     return 
  32. //都等于1表示成功,可以提交事务,修改数据 
  33. if 张三受影响行数==1 && 李四受影响行数==1{ 
  34.     //提交事务 
  35.     fmt.Println("提交事务"
  36.     tx.Commit() 
  37. }else
  38.     //有一个!=1表示没有更新成功,可能用户不存在 
  39.     fmt.Println("失败了,事物回滚了"
  40.     tx.Rollback() 
  41. fmt.Println("事物执行成功"

执行结果

 Go语言增强版操作MySQL(SQLX)

Mysql

 Go语言增强版操作MySQL(SQLX)

NameExec

做增 删 改使用。

NameExec方法是通过结构体或Map绑定SQL语句,试了试,感觉用处不大,不做举例。

NameQuery

做查询使用。

用法同上,没用,不做举例。

总结

其实sqlx模块,最大的改进是在查询方面,相信你也看到了,确实会比原生查询方便很多很多。

但是在其他方便,就显得捉襟见肘了,但是又说,一般还是查询场景多,查多改少。

原文地址:https://mp.weixin.qq.com/s/bvukb-5s5qT9BfixPxlUXA

延伸 · 阅读

精彩推荐
  • Golanggolang json.Marshal 特殊html字符被转义的解决方法

    golang json.Marshal 特殊html字符被转义的解决方法

    今天小编就为大家分享一篇golang json.Marshal 特殊html字符被转义的解决方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧 ...

    李浩的life12792020-05-27
  • Golanggo语言制作端口扫描器

    go语言制作端口扫描器

    本文给大家分享的是使用go语言编写的TCP端口扫描器,可以选择IP范围,扫描的端口,以及多线程,有需要的小伙伴可以参考下。 ...

    脚本之家3642020-04-25
  • GolangGolang中Bit数组的实现方式

    Golang中Bit数组的实现方式

    这篇文章主要介绍了Golang中Bit数组的实现方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    天易独尊11682021-06-09
  • GolangGolang通脉之数据类型详情

    Golang通脉之数据类型详情

    这篇文章主要介绍了Golang通脉之数据类型,在编程语言中标识符就是定义的具有某种意义的词,比如变量名、常量名、函数名等等,Go语言中标识符允许由...

    4272021-11-24
  • Golanggolang 通过ssh代理连接mysql的操作

    golang 通过ssh代理连接mysql的操作

    这篇文章主要介绍了golang 通过ssh代理连接mysql的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    a165861639710342021-03-08
  • Golanggo日志系统logrus显示文件和行号的操作

    go日志系统logrus显示文件和行号的操作

    这篇文章主要介绍了go日志系统logrus显示文件和行号的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    SmallQinYan12302021-02-02
  • Golanggolang如何使用struct的tag属性的详细介绍

    golang如何使用struct的tag属性的详细介绍

    这篇文章主要介绍了golang如何使用struct的tag属性的详细介绍,从例子说起,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看...

    Go语言中文网11352020-05-21
  • Golanggolang的httpserver优雅重启方法详解

    golang的httpserver优雅重启方法详解

    这篇文章主要给大家介绍了关于golang的httpserver优雅重启的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,...

    helight2992020-05-14