在golang中操作mysql数据库的实现代码
程序员文章站
2023-01-18 23:31:28
前言
golang 提供了database/sql包用于对sql数据库的访问, 作为操作数据库的入口对象sql.db, 主要为我们提供了两个重要的功能:
̶...
前言
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数据库的实现代码,希望对大家有所帮助
上一篇: 新鲜逗人的雷语俏皮话
推荐阅读
-
php中实现mysql数据库备份与linux自动定时备份代码_PHP教程
-
在SQL 2005中实现循环每一行做一定的操作_MySQL
-
php下将图片以二进制存入mysql数据库中并显示的实现代码
-
PHP中操作MySQL数据库的注意事项_PHP
-
C++对Mysql数据库的访问查询(基于Mysql5.0的API,vs2010中操作
-
在Python的框架中为MySQL实现restful接口的教程
-
简单的php操作mysql数据库实现
-
mysql数据库,在查询列名里子查询一列由两列组合去重的个数如何实现?
-
在MySQL数据库中执行SQL语句时的几个注意点_MySQL
-
php中操作memcached缓存进行增删改查数据的实现代码,phpmemcached