在golang中操作mysql数据库的实现代码

作者:JimPang 时间:2024-01-15 14:41:51 

前言

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数据库的实现代码网站的支持!

来源:https://studygolang.com/articles/14642

标签:golang,mysql
0
投稿

猜你喜欢

  • asp 分页函数,可以显示 1,2,3,4,5... 前十页,后十页,下一页,上一页

    2009-07-05 18:34:00
  • 详解python OpenCV学习笔记之直方图均衡化

    2022-12-29 20:37:22
  • HTML5 声明兼容IE的写法

    2011-06-06 10:34:00
  • 如何让vsCode显示中文界面

    2023-05-31 10:22:50
  • Python reduce()函数的用法小结

    2022-02-27 11:28:45
  • Golang中的错误处理深入分析

    2024-02-18 20:59:46
  • PHP面向对象程序设计之类与反射API详解

    2023-11-19 12:44:12
  • django的ORM模型的实现原理

    2022-08-26 00:57:33
  • Python django导出excel详解

    2021-06-15 17:12:19
  • 微信公众平台开发教程③ PHP实现微信公众号支付功能图文详解

    2023-11-18 19:09:27
  • python 基于Appium控制多设备并行执行

    2022-12-11 12:00:06
  • 22个国外的Web在线编辑器收集

    2023-10-09 18:09:59
  • 如何用python批量调整视频声音

    2023-10-14 06:51:57
  • python实现K近邻回归,采用等权重和不等权重的方法

    2021-12-21 19:29:26
  • Pycharm配置opencv与numpy的实现

    2021-09-19 08:20:55
  • 设计与用户体验

    2009-05-06 13:36:00
  • 如何在Django中设置定时任务的方法示例

    2023-03-21 06:19:07
  • python中为main方法传参问题

    2023-05-20 04:48:12
  • 使用Python实现从各个子文件夹中复制指定文件的方法

    2023-11-09 12:04:05
  • python人工智能tensorflow构建卷积神经网络CNN

    2023-01-09 21:49:10
  • asp之家 网络编程 m.aspxhome.com