驱动包
MySql驱动
Go语言中的database/sql包不包含数据库驱动,使用时必须注入一个数据库驱动。
下载依赖
go get -u github.com/go-sql-driver/mysql
使用mysql驱动
语法:
func Open(driverName, dataSourceName string) (*DB, error)
示例代码:
import (
"database/sql"
"fmt"
_ "github.com/go-sql-driver/mysql"// _ 表示只引用 init函数
)
func main() {
dsn := "root:123456@tcp(127.0.0.1:3306)/go_test"
//Open打开一个dirverName指定的数据库,dataSourceName指定数据源
db,err := sql.Open("mysql",dsn)
if err != nil{
fmt.Println("打开数据库失败,err:%v\n",err)
return
}
//Open函数可能只是验证其参数,Ping方法可检查数据源名称是否合法。
err = db.Ping()
if err != nil{
fmt.Println("连接数据库失败,err:%v\n",err)
return
}
fmt.Println("连接数据库成功!")
}
初始化连接
返回的DB可以安全的被多个goroutine同时使用,并会维护自身的闲置连接池。
import (
"database/sql"
"fmt"
_ "github.com/go-sql-driver/mysql"
)
//定义一个全局对象db
var db *sql.DB
//定义一个初始化数据库的函数
func initDB() (err error) {
dsn := "root:123456@tcp(127.0.0.1:3306)/go_test"
db,err := sql.Open("mysql",dsn)
if err != nil{
return err
}
//尝试与数据库连接,校验dsn是否正确
err = db.Ping()
if err != nil{
fmt.Println("校验失败,err",err)
return err
}
// 设置最大连接数
db.SetMaxOpenConns(50)
// 设置最大的空闲连接数
db.SetMaxIdleConns(20)
fmt.Println("连接数据库成功!")
return nil
}
func main() {
err := initDB()
if err != nil{
fmt.Println("init db失败,err",err)
return
}
}
其中sql.DB是一个数据库(操作)句柄,代表一个具有零到多个底层连接的连接池。它可以安全的被多个go程同时使用。database/sql包会自动创建和释放连接;它也会维护一个闲置连接的连接池。
SetMaxOpenConns
语法:
func (db *DB) SetMaxOpenConns(n int)
db.SetMaxOpenConns(10)
SetMaxOpenConns设置与数据库建立连接的最大数目。 如果n大于0且小于最大闲置连接数,会将最大闲置连接数减小到匹配最大开启连接数的限制。 如果n<=0,不会限制最大开启连接数,默认为0(无限制)。
SetMaxIdleConns
语法:
func (db *DB) SetMaxIdleConns(n int)
db.SetMaxIdleConns(5)
SetMaxIdleConns设置连接池中的最大闲置连接数。 如果n大于最大开启连接数,则新的最大闲置连接数会减小到匹配最大开启连接数的限制。 如果n<=0,不会保留闲置连接。
GUID
建库建表语句
> CREATE DATABASE go_test;
> use go_test;
> CREATE TABLE `user` (
`id` BIGINT(20) NOT NULL AUTO_INCREMENT,
`name` VARCHAR(20) DEFAULT '',
`age` INT(11) DEFAULT '0',
PRIMARY KEY(`id`)
)ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;
查询
单行查询
单行查询db.QueryRow()执行一次查询,并期望返回最多一行结果(即Row)。
语法:
func (db *DB) QueryRow(query string, args ...inter