前言

go在操作MySQL时,可以使用ORM(比如gorm、xorm),也可以使用原生sql。本文以使用sqlx为例,简单记录步骤。

  • go version: 1.16
  • 安装相关库
# mysql驱动
go get github.com/go-sql-driver/mysql
# 基于MySQL驱动的封装
go get github.com/jmoiron/sqlx
  • 连接MySQL
database, err := sqlx.Open("mysql", "username:password@tcp(127.0.0.1:3306)/dbName")
  • 测试数据表定义:
CREATE TABLE `person` (
`user_id` INT(11) NOT NULL AUTO_INCREMENT,
`username` VARCHAR(260) NULL DEFAULT NULL COLLATE 'utf8_general_ci',
`sex` VARCHAR(260) NULL DEFAULT NULL COLLATE 'utf8_general_ci',
`email` VARCHAR(260) NULL DEFAULT NULL COLLATE 'utf8_general_ci',
PRIMARY KEY (`user_id`) USING BTREE
)
COLLATE='utf8_general_ci'
ENGINE=InnoDB
AUTO_INCREMENT=2
;

初始化MySQL连接

// 数据表person的结构体
type Person struct {
UserId int `db:"user_id"`
Username string `db:"username"`
Sex string `db:"sex"`
Email string `db:"email"`
}
func init() {
// 初始化建立MySQL连接
database,err := sqlx.Open("mysql", "root:123456@tcp(127.0.0.1:3306)/gotest")
if err != nil {
fmt.Println("open mysql failed. ",err)
return
}
// database.SetMaxOpenConns(200)
// database.SetMaxIdleConns(10)
db = database
// defer db.Close()
}

插入数据

func InsertData() {
// 插入数据方式1
result,err := db.Exec("insert into person(username,sex,email) values(?,?,?)", "stu002", "woman", "stu002@email.com")
if err != nil {
fmt.Println("insert data failed, ",err)
return
}
id, err := result.LastInsertId()
if err != nil {
fmt.Println("insert data failed2, ",err)
return
}
fmt.Println("insert data success, ",id)
} func InsertData2() {
// 插入数据方式2
sqlStr := "insert into person(username,sex,email) values(:username,:sex,:email)"
result,err := db.NamedExec(sqlStr,map[string]interface{}{
"username": "stu003",
"sex": "man",
"email": "stu003@email.com",
})
if err != nil {
fmt.Println("insert data failed, ",err)
return
}
id, err := result.LastInsertId()
if err != nil {
fmt.Println("insert data failed2, ",err)
return
}
fmt.Println("insert data success, ",id)
}

删除数据

func DeleteData() {
// delete 删除数据
result,err := db.Exec("delete from person where username=? and sex=?","stu002","woman")
if err != nil {
fmt.Println("delete data failed, ",err)
return
}
row,err := result.RowsAffected()
if err != nil {
fmt.Println("affected row unknown, ",err)
}
fmt.Println("delete data success: ",row)
}

修改数据

func UpdateData() {
// update修改数据
result,err := db.Exec("update person set sex=? where username=?","woman","stu001")
if err != nil {
fmt.Println("update data failed, ",err)
return
}
row,err := result.RowsAffected()
if err != nil {
fmt.Println("affected row unknown, ",err)
}
fmt.Println("update data success: ",row)
}

查询数据

func SelectData() {
// 查询数据
var person Person
err := db.Get(&person, "select user_id,username,sex,email from person where user_id=?", 2)
if err != nil {
fmt.Println("select data failed, ",err)
return
}
fmt.Println(person.Email)
} func SelectData2() {
// 查询数据方式2
sqlStr := "select user_id,username,sex,email from person where user_id=:user_id"
rows,err := db.NamedQuery(sqlStr,map[string]interface{}{
"user_id": "2",
})
if err != nil {
fmt.Println("query data error, ",err)
return
}
for rows.Next() {
var person Person
if err := rows.StructScan(&person);err != nil {
fmt.Printf("struct scan failed, %v\n",err)
continue
}
fmt.Println(person)
}
}

事务操作

  • 开启事务:
func (db *DB) Begin() (*Tx, error)
  • 回滚事务:
func (tx *Tx) Rollback() error
  • 提交事务
func (tx *Tx) Commit() error
  • 示例:
func InsertDataTransaction() {
tx,err := db.Begin()
if err != nil {
fmt.Println("transaction begin failed, ",err)
return
}
defer func() {
if p := recover(); p != nil {
_ = tx.Rollback()
panic(p)
} else if err != nil {
fmt.Printf("transaction rollback")
_ = tx.Rollback()
} else {
err = tx.Commit()
fmt.Printf("transaction commit")
return
}
}() sqlStr := "insert into person(username,sex,email) values(?,?,?)"
result,err := tx.Exec(sqlStr,"stu004", "woman", "stu004@email.com")
if err != nil {
fmt.Println("insert data failed, ",err)
return
}
_,err = result.RowsAffected()
if err != nil {
fmt.Println("affected rows num is 0")
return
}
}

完整示例代码

package main
import (
"fmt"
_ "github.com/go-sql-driver/mysql"
"github.com/jmoiron/sqlx"
) // 数据表person的结构体
type Person struct {
UserId int `db:"user_id"`
Username string `db:"username"`
Sex string `db:"sex"`
Email string `db:"email"`
} // 数据表place的结构体
type Place struct {
Country string `db:"country"`
City string `db:"city"`
Telcode int `db:"telcode"`
} var db *sqlx.DB func init() {
// 初始化建立MySQL连接
database,err := sqlx.Open("mysql", "root:123456@tcp(127.0.0.1:3306)/gotest")
if err != nil {
fmt.Println("open mysql failed. ",err)
return
}
// database.SetMaxOpenConns(200)
// database.SetMaxIdleConns(10)
db = database
// defer db.Close()
} func InsertData() {
// 插入数据
result,err := db.Exec("insert into person(username,sex,email) values(?,?,?)", "stu002", "woman", "stu002@email.com")
if err != nil {
fmt.Println("insert data failed, ",err)
return
}
id, err := result.LastInsertId()
if err != nil {
fmt.Println("insert data failed2, ",err)
return
}
fmt.Println("insert data success, ",id)
} func InsertData2() {
// 插入数据
sqlStr := "insert into person(username,sex,email) values(:username,:sex,:email)"
result,err := db.NamedExec(sqlStr,map[string]interface{}{
"username": "stu003",
"sex": "man",
"email": "stu003@email.com",
})
if err != nil {
fmt.Println("insert data failed, ",err)
return
}
id, err := result.LastInsertId()
if err != nil {
fmt.Println("insert data failed2, ",err)
return
}
fmt.Println("insert data success, ",id)
} func SelectData() {
// 查询数据
var person Person
err := db.Get(&person, "select user_id,username,sex,email from person where user_id=?", 2)
if err != nil {
fmt.Println("select data failed, ",err)
return
}
fmt.Println(person.Email)
} func SelectData2() {
// 查询数据方式2
sqlStr := "select user_id,username,sex,email from person where user_id=:user_id"
rows,err := db.NamedQuery(sqlStr,map[string]interface{}{
"user_id": "2",
})
if err != nil {
fmt.Println("query data error, ",err)
return
}
for rows.Next() {
var person Person
if err := rows.StructScan(&person);err != nil {
fmt.Printf("struct scan failed, %v\n",err)
continue
}
fmt.Println(person)
}
} func UpdateData() {
// update修改数据
result,err := db.Exec("update person set sex=? where username=?","woman","stu001")
if err != nil {
fmt.Println("update data failed, ",err)
return
}
row,err := result.RowsAffected()
if err != nil {
fmt.Println("affected row unknown, ",err)
}
fmt.Println("update data success: ",row)
} func DeleteData() {
// delete 删除数据
result,err := db.Exec("delete from person where username=? and sex=?","stu002","woman")
if err != nil {
fmt.Println("delete data failed, ",err)
return
}
row,err := result.RowsAffected()
if err != nil {
fmt.Println("affected row unknown, ",err)
}
fmt.Println("delete data success: ",row)
} func InsertDataTransaction() {
tx,err := db.Begin()
if err != nil {
fmt.Println("transaction begin failed, ",err)
return
}
defer func() {
if p := recover(); p != nil {
_ = tx.Rollback()
panic(p)
} else if err != nil {
fmt.Printf("transaction rollback")
_ = tx.Rollback()
} else {
err = tx.Commit()
fmt.Printf("transaction commit")
return
}
}() sqlStr := "insert into person(username,sex,email) values(?,?,?)"
result,err := tx.Exec(sqlStr,"stu004", "woman", "stu004@email.com")
if err != nil {
fmt.Println("insert data failed, ",err)
return
}
_,err = result.RowsAffected()
if err != nil {
fmt.Println("affected rows num is 0")
return
}
} func main() {
// InsertData()
// InsertData2()
// SelectData()
// SelectData2()
// UpdateData()
// DeleteData()
InsertDataTransaction()
defer db.Close()
}

参考

【go笔记】使用sqlx操作MySQL的更多相关文章

  1. sqlx操作MySQL实战及其ORM原理

    sqlx是Golang中的一个知名三方库,其为Go标准库database/sql提供了一组扩展支持.使用它可以方便的在数据行与Golang的结构体.映射和切片之间进行转换,从这个角度可以说它是一个OR ...

  2. python学习笔记十一:操作mysql

    一.安装MySQL-python # yum install -y MySQL-python 二.打开数据库连接 #!/usr/bin/python import MySQLdb conn = MyS ...

  3. 【PHP+MySQL学习笔记】php操作MySQL数据库中语句

    1.连接 MYSQL 服务器的函数 mysql_connect();<?php $con = mysql_connect("localhost","root&quo ...

  4. 笔记-python操作mysql

    笔记-python操作mysql 1.      开始 1.1.    环境准备-mysql create database db_python; use db_python; create tabl ...

  5. 18 . Go之操作Mysql和sqlx使用

    安装mysql wget http://dev.mysql.com/get/mysql57-community-release-el7-8.noarch.rpm yum -y localinstall ...

  6. GO学习-(23) Go语言操作MySQL + 强大的sqlx

    Go语言操作MySQL MySQL是业界常用的关系型数据库,本文介绍了Go语言如何操作MySQL数据库. Go操作MySQL 连接 Go语言中的database/sql包提供了保证SQL或类SQL数据 ...

  7. python学习笔记-(十六)python操作mysql

    一. mysql安装 1. windows下安装mysql 1.1. 下载源: http://dev.mysql.com/downloads/installer/,请认准对应版本 Windows (x ...

  8. php笔记08:数据库编程---使用php的MySQL扩展库操作MySQL数据库

    1.使用php的MySQL扩展库操作MySQL数据库: php有3种方式操作MySQL数据库 (1)mysql扩展库 (2)mysqli扩展库 (3)pdo     mysql扩展库与mysql数据库 ...

  9. Java框架spring Boot学习笔记(五):Spring Boot操作MySQL数据库增、删、改、查

    在pom.xml添加一下代码,添加操作MySQL的依赖jar包. <dependency> <groupId>org.springframework.boot</grou ...

  10. Java框架spring Boot学习笔记(四):Spring Boot操作MySQL数据库

    在pom.xml添加一下代码,添加操作MySQL的依赖jar包. <dependency> <groupId>org.springframework.boot</grou ...

随机推荐

  1. 记录内网Docker启动Stable-Diffusion遇到的几个坑

    摘要:最近看到K8s启动stable-diffusion的文章,想着在自己开发环境复现一下.没想到在内网环境还遇到这么多问题,记录一下. 本文分享自华为云社区<内网Docker启动Stable- ...

  2. 中文环境下使用 huggingface 模型替换 OpenAI的Embedding 接口

    OpenAI的文本嵌入衡量文本字符串的相关性.嵌入通常用于: 搜索(其中结果按与查询字符串的相关性排名) 聚类(其中文本字符串按相似性分组) 推荐(推荐具有相关文本字符串的项目) 异常检测(识别出相关 ...

  3. 2013年蓝桥杯C/C++大学A组省赛真题(颠倒的价牌)

    题目描述: 小李的店里专卖其它店中下架的样品电视机,可称为:样品电视专卖店. 其标价都是4位数字(即千元不等). 小李为了标价清晰.方便,使用了预制的类似数码管的标价签,只要用颜色笔涂数字就可以了(参 ...

  4. 数学建模 Excel的批量写入与批量导出

    数学建模中编程手们常常会被要求将大量的数据进行批量的预测操作,并写入某个文件中 Excel的批量导出数据,用循环就可以简单实现,例如 import pandas as pd for i in list ...

  5. RWKV – transformer 与 RNN 的强强联合

    在 NLP (Natural Language Processing, 自然语言处理) 领域,ChatGPT 和其他的聊天机器人应用引起了极大的关注.每个社区为构建自己的应用,也都在持续地寻求强大.可 ...

  6. Bio+IT 生信科技爱好者知识库

    欢迎来到 Bio+IT 生信科技爱好者知识库! 关于我们 "BioIT爱好者" 是一个专注于生物信息学和 IT 互联网技术的知识库平台,是一个集合了 Bio+IT 相关的数据分析. ...

  7. 基于 prefetch 的 H5 离线包方案

    前言 对于电商APP来讲,使用H5技术开发的页面占比很高.由于H5加载速度非常依赖网络环境,所以为了提高用户体验,针对H5加载速度的优化非常重要.离线包是最常用的优化技术,通过提前下载H5渲染需要的H ...

  8. youtobe深度学习推荐系统-学习笔记

    简介 前言 本文是Deep Neural Networks for YouTube Recommendations 论文的学习笔记.淘宝的召回模型曾经使用过这篇论文里面的方案,后续淘宝召回模型升级到了 ...

  9. 自然语言处理 Paddle NLP - 词法分析技术及其应用

    词法分析就是利用计算机对自然语言的形态(morphology) 进行分析,判断词的结构和类别等."简单而言,就是分词并对每个词进行分类,包括:分词.词性标注.实体识别三个任务 问答 知识图谱 ...

  10. 前端vue基于原生check增强单选多选插件

    前端vue基于原生check增强单选多选插件, 下载完整代码请访问uni-app插件市场地址:https://ext.dcloud.net.cn/plugin?id=12979 效果图如下:     ...