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

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

内容简介: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()
}

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

查看所有标签

猜你喜欢:

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

大型分布式网站架构设计与实践

大型分布式网站架构设计与实践

陈康贤 / 电子工业出版社 / 2014-9-1 / 79.00元

《大型分布式网站架构设计与实践》主要介绍了大型分布式网站架构所涉及的一些技术细节,包括SOA架构的实现、互联网安全架构、构建分布式网站所依赖的基础设施、系统稳定性保障和海量数据分析等内容;深入地讲述了大型分布式网站架构设计的核心原理,并通过一些架构设计的典型案例,帮助读者了解大型分布式网站设计的一些常见场景及遇到的问题。 作者结合自己在阿里巴巴及淘宝网的实际工作经历展开论述。《大型分布式网站......一起来看看 《大型分布式网站架构设计与实践》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

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

在线XML、JSON转换工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换