• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    在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数据库的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

    您可能感兴趣的文章:
    • Golang操作MySql数据库的完整步骤记录
    • 如何利用Golang解析读取Mysql备份文件
    • Golang中如何对MySQL进行操作详解
    • golang gorm 操作mysql及gorm基本用法
    • golang实现mysql数据库备份的操作方法
    • golang中连接mysql数据库
    上一篇:centos7.4系统中yum源安装mysql 5.6
    下一篇:mysql增量备份及断点恢复脚本实例
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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