golang实现MySQL数据库事物的提交与回滚

栏目: Go · 发布时间: 7年前

内容简介:MySQL 事务主要用于处理操作量大,复杂度高的数据。在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。事务用来管理 insert,update,delete 语句,事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。一般来说,事务是必须满足4个条件(ACID)::原子性(Atomicity,或称不可分割性)、一致性(Consistency)、隔离性(Isolation,又称独立性)、持久性(Durability)。本文主要介绍golang实

MySQL 事务主要用于处理操作量大,复杂度高的数据。在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。事务用来管理 insert,update,delete 语句,事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。

一般来说,事务是必须满足4个条件(ACID)::原子性(Atomicity,或称不可分割性)、一致性(Consistency)、隔离性(Isolation,又称独立性)、持久性(Durability)。

本文主要介绍golang实现MySQL数据库事物的提交与回滚。用到的库有:

"github.com/jmoiron/sqlx"

_ "github.com/go-sql-driver/mysql"

事务(Transactions)

事务操作是通过三个方法实现:

Begin():开启事务

Commit():提交事务(执行sql)

Rollback():回滚

举例:在事物里操作MySQL任意一步操作出错,都需要Rollback()回滚。

package main
 
import (
    "fmt"
    "github.com/alecthomas/log4go"
    _ "github.com/go-sql-driver/mysql"
    "github.com/jmoiron/sqlx"
)
 
var Db *sqlx.DB
 
func init()  {
    db,err:=sqlx.Open("mysql","TigerwolfC:123456@tcp(127.0.0.1:3306)/test?charset=utf8")
    if err != nil {
        fmt.Println("open mysql failed,", err)
        return
    }
    Db = db
}
 
func main()  {
    mysqlTest()
}
 
 
func mysqlTest() error{
    tx, err := Db.Begin()
    if err != nil {
        log4go.Error("open mysql database fail", err)
        return err
    }
 
    result, err := tx.Exec("INSERT INTO userinfo (username, password,department,email) VALUES (?, ?,?,?)","cici","33333","it","TigerwolfC@163.com")
    if err != nil{
        fmt.Println("insert failed,error: ", err)
        tx.Rollback()
        return err
    }
    id,_ := result.LastInsertId()
    fmt.Println("insert id is :",id)
    _, err = tx.Exec("update userinfo set department = ? where username = ?","cekong","hahah")
    if err != nil{
        fmt.Println("update failed error:",err)
        tx.Rollback()
        return err
    } else {
        fmt.Println("update success!")
    }
    _, err = tx.Exec("delete from userinfo where username = ? ", "weiwei")
    if err != nil{
        fmt.Println("delete error:",err)
        tx.Rollback()
        return err
    }else{
        fmt.Println("delete success")
    }
    return tx.Commit()
}

当然也可以用defer tx.Rollback(),在程序退出前回滚。

func mysqlTest() error{
    tx, err := Db.Begin()
    if err != nil {
        log4go.Error("open mysql database fail", err)
    }
    defer tx.Rollback()
 
    result, err := tx.Exec("INSERT INTO userinfo (username, password,department,email) VALUES (?, ?,?,?)","cici","33333","it","TigerwolfC@163.com")
    if err != nil{
        fmt.Println("insert failed,error: ", err)
        return err
    }
    id,_ := result.LastInsertId()
    fmt.Println("insert id is :",id)
    _, err = tx.Exec("update userinfo set department = ? where username = ?","cekong","hahah")
    if err != nil{
        fmt.Println("update failed error:",err)
        return err
    } else {
        fmt.Println("update success!")
    }
    _, err = tx.Exec("delete from userinfo where username = ? ", "weiwei")
    if err != nil{
        fmt.Println("delete error:",err)
        return err
    }else{
        fmt.Println("delete success")
    }
    return tx.Commit()
}

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

互联网+秋叶课堂:我的网课创业

互联网+秋叶课堂:我的网课创业

秋叶 / 北京:机械工业出版社 / 2016-3-1 / 39.0

在线教育被很多人视为 “互联网+”创业热潮中的下一个风口,越来越多的老师和创业者选择在线教育创业。本书作者秋叶老师2013年双11正式带一帮小伙伴开始在线教育创业,在短短两年内“从0到1”,累计做到了超500万元的销售业绩,成为国内Office领域在线教育运营最成功的团队之一。在这本书中秋叶老师结合自己的实战经历,向各位完整剖析了两年创业的真实复盘思考,是一本值得在线教育创业同行入手的必读书。 ......一起来看看 《互联网+秋叶课堂:我的网课创业》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具