go mysql 异步_GO操作MYSQL

驱动包

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值