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

前言

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数据库的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

您可能感兴趣的文章:Go语言操作mysql数据库简单例子

Go语言使用MySql的方法

Go语言中http和mysql的实现代码

Golang中如何对MySQL进行操作详解

golang gorm 操作mysql及gorm基本用法

golang实现mysql数据库备份的操作方法

Go语言集成mysql驱动、调用数据库、查询数据操作示例

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值