经过度娘后,发现比较常用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)