MySQL驱动安装
使用数据库之前,必须安装相关MySQL数据驱动[1],如果未安装驱动或者没有引入驱动库会报以下错误:
failed to open database: sql: unknown driver "mysql" (forgotten import?)
安装golang mysql driver
go get github.com/go-sql-driver/mysql
代码中还需注册数据库驱动,通过引入空白倒入[2]mysql包来完成
func init() {
sql.Register("mysql", &MySQLDriver{})
}
准备测试数据
连接MySQL
mysql -uroot -p
选择数据库test
use test
创建测试用的users表和order表,并插入测试数据
#创建user表
DROP TABLE IF EXISTS `order`;
DROP TABLE IF EXISTS `user`;
CREATE TABLE IF NOT EXISTS `user` (`uid` SERIAL PRIMARY KEY, `name` VARCHAR(20) NOT NULL, `password` VARCHAR(20) NOT NULL) ENGINE=`innodb`, CHARACTER SET=utf8;
#创建order表
CREATE TABLE IF NOT EXISTS `order`(`oid` SERIAL PRIMARY KEY, `uid` BIGINT(20) UNSIGNED NOT NULL, `date` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, FOREIGN KEY (`uid`) REFERENCES `user`(`uid`))ENGINE=innodb,CHARACTER SET=utf8;
#插入测试数据
INSERT INTO `user`(`name`,`password`) VALUES(‘nick‘, ‘nick‘),(‘jacky‘, ‘jacky‘);
INSERT INTO `order`(`uid`) VALUES(1),(2);
连接数据库
连接数据的DSN格式为:
username:password@protocol(address)/dbname?param=value
示例代码:
db, err := sql.Open("mysql", "root:root@tcp(127.0.0.1:3306)/test?charset=utf8")
if err != nil {
fmt.Println("failed to open database:", err.Error())
return
}
if err := db.Ping(); err != nil {
fmt.Println("%s error ping database: %s", err.Error())
return
}
defer db.Close()
返回的DB对象,实际封装了一个数据库连接池,对于goroutine是线程安全的,可以放心使用。这个数据库连接池由"database/sql"包负责自动创建和回收。连接池的大小可以由SetMaxIdleConns指定。
需要注意的是,创建DB对象成功,并不代表已经成功的连接了数据库,数据库连接只有在真正需要的时候才会被创建。因此如果,在创建DB对象后想验证数据库连接是否有效,可以调用Ping()或者通过