分享
  1. 首页
  2. 文章

javaer to go之mysql操作

p_3er · · 1747 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

经过度娘后,发现比较常用golang mysql驱动包有两种mymysql和go-sql-driver/mysql。个人觉得mymysql这个名字起得不够文雅。所以我选择了go-sql-driver/mysql。

1、go-sql-driver/mysql的安装

因为go-sql-driver/mysql属于第三方的包,所以我们需要先获取到这个包。

通过系统的shell工具(命令行),把安装包加到我们的$GOPATH。

go get github.com/go-sql-driver/mysql

这里要注意的是:使用上面的命令不单要配置好Golang的环境,还需要把git的bin目录配置到Path环境变量中。

2、操作mysql

  • 导包
import (
 "database/sql"
 _ "github.com/go-sql-driver/mysql"
)

因为我们使用过程中,并没有直接使用到go-sql-driver/mysql,而是通过database/sql中的接口来使用驱动,这点和java的思想是一样的。所以我们在导入go-sql-driver/mysql包的时候,通过下划线作为占位符,告诉golang不会直接使用此包的内容。

注:

如果你导入了一个包却没有使用它,则会在构建程序时引发错误,如 imported and not used: os,这正是遵循了 Go 的格言:"没有不必要的代码!"。

变量的声明也一样,你如果声明了一个变量,却没有使用这个变量,也会引发错误。

占位符的存在,解决了你既要导入这个包,但又不会显式使用包的问题。

  • 建立连接
db, err := sql.Open("mysql", "用户名:密码@/数据库名?charset=utf8")

Open函数会返回两个值,但我们如果只需要db值,而不考虑error的话,可以使用占位符:

db, _:= sql.Open("mysql", "用户名:密码@/数据库名?charset=utf8")
  • Exec
_, err := db.Exec(sql)

Exec函数可以执行一条无返回的sql,如delete、update、insert操作。

  • Prepare
    预处理折方式处理sql
    如:

增加:

stmt, err := db.Prepare(`INSERT user (user_name,user_age,user_sex) values (?,?,?)`)
checkErr(err)
res, err := stmt.Exec("tony", 20, 1)
checkErr(err)
id, err := res.LastInsertId()
checkErr(err)

修改:

stmt, err := db.Prepare(`UPDATE user SET user_age=?,user_sex=? WHERE user_id=?`)
checkErr(err)
res, err := stmt.Exec(21, 2, 1)
checkErr(err)
num, err := res.RowsAffected()
checkErr(err)

删除:

stmt, err := db.Prepare(`DELETE FROM user WHERE user_id=?`)
checkErr(err)
res, err := stmt.Exec(1)
checkErr(err)
num, err := res.RowsAffected()
checkErr(err)
  • Query

查询返回多条记录。

 rows, err := db.Query("select id,nickname from user")
 if err != nil {
 fmt.Println(err.Error())
 }
 defer rows.Close()
 for rows.Next() {
 var id int
 var nickname string
 rows.Scan(&id, &nickname)
 fmt.Println(nickname)
 }
 db.Close()
  • QueryRow
    查询返回一条记录。
 row := Open().QueryRow("select id,nickname from user where id=129986")
 var id int
 var nickname string
 row.Scan(&id, &nickname)

有疑问加站长微信联系(非本文作者)

本文来自:CSDN博客

感谢作者:p_3er

查看原文:javaer to go之mysql操作

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
1747 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏