javaer to go之mysql操作

经过度娘后,发现比较常用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)
上一篇:DataWorks数据集成与开源Sqoop的对比


下一篇:使用canal增量同步mysql数据库信息到ElasticSearch