Go语言从入门到精通 -【web项目实战篇】- MySQL的事物

本节核心内容

  • 介绍了为什么要使用事物
  • 介绍事物对象的常用方法
  • 介绍事物的应用场景
  • 介绍事物的ACID
  • 演示了事物的示例代码
  • 介绍开发中需要注意的点

本小节视频教程和代码:百度网盘

可先下载视频和源码到本地,边看视频边结合源码理解后续内容,边学边练。

事务(transaction)

事物:保持逻辑数据一致性与可恢复性,必不可少的利器!

为什么要使用事务

银行转账是经典的解释事务的例子,如:用户A给用户B转账5000元主要步骤可以概括为以下几步:

  1. 检测A账户余额 > 5000元

  2. A账户余额减去 5000元

  3. B账户余额增加 5000元

这几步要么都成功,要么一个都不成功,否则都会导致数据不一致(5000元不翼而飞)。这就可以用到事务来保证,如果是不同银行之间的转账还需要用到分布式事务。

事物对象的常用方法

  • Tx, err := Db.Begin() 开启事务
  • Tx.Exec() 执行事务
  • Tx.Commit() 提交事务
  • Tx.Rollback() 回滚事务
  • Tx.Query()查询语句
  • Tx.QueryRow()查询语句,但只返回一行

事务的应用场景

  1. 1. 同时更新多个表  
  2. 2. 同时更新多行数据  

事务的ACID

  1. 1. 原子性  

    一个事务的执行被视为一个不可分割的最小单元。事务里面的操作,要么全部成功执行,要么全部失败回滚。

  2. 2. 一致性  

    事务结束的时候,所有的内部数据都是正确的。

  3. 3. 隔离性  

    并发多个事务时,各个事务不干涉内部数据,处理的都是另外一个事务处理之前或之后的数据。

  4. 4. 持久性 

    事务提交之后,数据是永久性的,不可再回滚。

示例代码

package main

import (
    "fmt"
    "database/sql"
    
    _ "github.com/go-sql-driver/mysql"
)


func Transaction(db *sql.DB) {

    // 开启事务
    tx, err := db.Begin()

    if err != nil {
        panic(err)
    }

    result, err := tx.Exec("insert into user(name, age)values(?,?)", "Jack", 98)
    if err != nil {
        // 失败回滚
        tx.Rollback()
        panic(err)
    }
    
    fmt.Println("result", result)

    exec, err := tx.Exec("update user set name=?, age=? where id=?", "Jack", 98, 1)
    if err != nil {
        // 失败回滚
        tx.Rollback()
        panic(err)
    }
    fmt.Println("exec", exec)

    // 提交事务
    err = tx.Commit()
    
    if err != nil {
        // 失败回滚
        tx.Rollback()
        panic(err)
    }
}

func main() {

    dns := "root:root@tcp(127.0.0.1:3306)/test"
    db, err := sql.Open("mysql", dns)
    if err != nil {
        panic(err)
    }

    err = db.Ping()
    if err != nil {
        panic(err)
    }

    Transaction(db)
}

需要注意的点

  1. 执行失败要回滚
  2. 提交失败要回滚

小结

本小节主要讲了事物对象的常用方法和事物的应用场景,以及在开发中需要注意的点

转载于:https://www.cnblogs.com/Survivalist/articles/10439122.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值