前言

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的驱动

go-sql-driver
 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方法直接实现

本文来自网络收集,不代表猴子技术宅立场,如涉及侵权请点击右边联系管理员删除。

如若转载,请注明出处:https://www.ssfiction.com/sqljc/944348.html