在golang中操作mysql数据库的实现代码
2018-09-04 14:19
836 查看
前言
Golang 提供了database/sql包用于对SQL数据库的访问, 作为操作数据库的入口对象sql.DB, 主要为我们提供了两个重要的功能:
•sql.DB 通过数据库驱动为我们提供管理底层数据库连接的打开和关闭操作.
•sql.DB 为我们管理数据库连接池
需要注意的是,sql.DB表示操作数据库的抽象访问接口,而非一个数据库连接对象;它可以根据driver打开关闭数据库连接,管理连接池。正在使用的连接被标记为繁忙,用完后回到连接池等待下次使用。所以,如果你没有把连接释放回连接池,会导致过多连接使系统资源耗尽。
Golang操作mysql简介
Golang操作mysql数据库的感觉有点想php中的pdo对mysql操作,假设你原本是phper转型到golang中的接受起来很亲切,总体的感觉非常简单
Golang操作mysql的注意点
golang实现了对mysql操作的标准库然而却没有实现mysql的驱动
因此我们需要先从github中下载
go-sql-driver这个驱动包(建议在src目录下执行),使用命令如下所示:
go get github.com/go-sql-driver/mysql
在test数据库中建立表字段如下所示
CREATE TABLE IF NOT EXISTS `test`.`user` ( `user_id` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '用户编号', `user_name` VARCHAR(45) NOT NULL COMMENT '用户名称', `user_age` TINYINT(3) UNSIGNED NOT NULL DEFAULT 0 COMMENT '用户年龄', `user_sex` TINYINT(3) UNSIGNED NOT NULL DEFAULT 0 COMMENT '用户性别', PRIMARY KEY (`user_id`)) ENGINE = InnoDB AUTO_INCREMENT = 1 DEFAULT CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '用户表'
实现对数据的增(insert)操作
package main import ( "fmt" "database/sql" //导入mysql的驱动 _ "github.com/go-sql-driver/mysql" ) func main(){ //使用database/sql包中的Open连接数据库 db,err := sql.Open("mysql","root:root@tcp(localhost:3306)/test?charset=utf8") if err != nil { fmt.Println("连接数据库失败:",err) return } //使用DB结构体实例方法Prepare预处理插入,Prepare会返回一个stmt对象 stmt,err := db.Prepare("insert into `user`(user_name,user_age,user_sex)values(?,?,?)") if err!=nil{ fmt.Println("预处理失败:",err) return } //使用Stmt对象执行预处理参数 result,err := stmt.Exec("pengjin",33,"男") if err!=nil{ fmt.Println("执行预处理失败:",err) return }else{ rows,_ := result.RowsAffected() fmt.Println("执行成功,影响行数",rows,"行" ) } }
如上代码有一种操作php中pdo的感觉 ,如上代码实际上也可以不编写Prepare方法直接通过Stmt实例的Exec方法直接实现
总结
以上所述是小编给大家介绍的在golang中操作mysql数据库的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
您可能感兴趣的文章:
相关文章推荐
- Java语言实现对MySql数据库中数据的增删改查操作的代码
- golang实现对mysql数据库的操作
- 代码片段 - Golang 实现集合操作
- PHP文件操作实现代码分享
- PHP文件操作实现代码分享
- [2012-10-10][转]C# WORD操作实现代码
- PHP5 操作MySQL数据库基础代码
- php xml文件操作实现代码(二)
- 操作GitHub实现代码托管
- 2、利用反射技术得到泛型类型,实现对实体添删改查操作进行代码重用设计
- Jquery操作单选按钮(Radio)的取值赋值实现代码
- Java中使用Jedis操作Redis的实现代码
- JAVA中通过代码操作PC内容进行功能的实现
- JavaScript 直接操作本地文件的实现代码
- 数据库SqlParameter 的插入操作,防止sql注入的实现代码
- jQuery select的操作实现代码
- jquery.cookie.js 操作cookie实现记住密码功能的实现代码
- Spark1.6.2 java实现读取txt文件插入MySql数据库代码
- [C语言教程]指针转换方式实现C语言的指针操作安全代码
- js实现键盘操作实现div的移动或改变的原理及代码