从Go连接MySQL的推荐方法是什么?

时间:2012-07-05 23:00:36

标签: mysql database go

我正在寻找一种可靠的解决方案来连接到Go的MySQL数据库。我见过一些库,但很难确定完整性和当前维护的不同状态。我没有复杂的需求,但我想知道人们依赖什么,或者什么是连接MySQL的最标准解决方案。

2 个答案:

答案 0 :(得分:257)

有一些驱动程序可用,但您应该只考虑那些实现database/sql API

的驱动程序
  • 它提供了一种干净有效的语法,
  • 它确保您可以在不更改代码的情况下更改驱动程序,除了导入和连接。

MySQL提供两种快速可靠的驱动程序:

我已经在生产中使用了它们,程序运行了数月,数百万的连接数没有失败。

其他SQL数据库驱动程序are listed on go-wiki

使用MyMySQL时导入:

import (
    "database/sql"
    _ "github.com/ziutek/mymysql/godrv"
)

使用Go-MySQL-Driver时导入:

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

使用MyMySQL连接和关闭:

con, err := sql.Open("mymysql", database+"/"+user+"/"+password)
defer con.Close()
// here you can use the connection, it will be closed when function returns

使用Go-MySQL-Driver连接和关闭:

con, err := sql.Open("mysql", store.user+":"+store.password+"@/"+store.database)
defer con.Close()

选择一行:

row := con.QueryRow("select mdpr, x, y, z from sometable where id=?", id)
cb := new(SomeThing)
err := row.Scan(&cb.Mdpr, &cb.X, &cb.Y, &cb.Z)

选择多行并构建包含结果的数组:

rows, err := con.Query("select a, b from item where p1=? and p2=?", p1, p2)
if err != nil { /* error handling */}
items := make([]*SomeStruct, 0, 10)
var ida, idb uint
for rows.Next() {
    err = rows.Scan(&ida, &idb)
    if err != nil { /* error handling */}
    items = append(items, &SomeStruct{ida, idb})
}

插入:

_, err = con.Exec("insert into tbl (id, mdpr, isok) values (?, ?, 1)", id, mdpr)

你会发现在Go with MySQL中工作是一种愉快的体验:我从不遇到问题,我的服务器运行了几个月而没有错误或泄漏。大多数函数只是采用可变数量的参数这一事实减轻了许多语言中繁琐的任务。

请注意,如果将来需要使用其他MySQL驱动程序,则只需在一个go文件中更改两行:执行导入的行和打开连接的行。

答案 1 :(得分:2)

很少有事情需要注意 选择1行示例:

row := con.QueryRow("select mdpr, x, y, z from sometable where id=?",id) 
cb := new(SomeThing) 
err := row.Scan(&cb.Mdpr, &cb.X, &cb.Y, &cb.Z)

此示例中缺少row.Next()。它需要调用row.Next()来获取返回的第一行。

对图书馆也存在一些不灵活性,它们在某种程度上试图促进数据极简主义。如果您尝试选择不是扫描的列,则会抛出错误(而不仅仅是警告)