7.事务操作

  1. 使用db.Begin()进行开启
  2. 操作数据库
  3. 开启成功之后,进行事务操作

操作-Exec

查询-Query

Go 复制代码
func main(){
    //连接数据库
    db,err := sql.Open("mysql","ims:123456@tcp(192.168.0.26:3306)/ibcf")
    if err != nil{
        log.Fatal("连接数据库失败:",err)    
    }
    //关闭连接
    defer db.Close()
    //验证是否连接成功
    err = db.Ping()
    if err != nil{
        log.Fatal("验证失败:",err)    
    }
    fmt.Println("连接成功!")
    //开启事务
    tx,err := db.Begin()
    if err != nil{
        log.Fatal("开启事务失败:",err)    
    }
    //操作数据库
   
    
    if _,err := tx.Exec("UPDATE user0 SET server_port = ? WHERE id = ?","1111",1);err != nil{
        tx.Rollback()//事务回滚
        log.Fatal("更新失败:",err)    
    }
    
     _,err := tx.Query("SELECT id,server_ip,server_port FROM user0")
    if err != nil{
        tx.Rollback()//事务回滚
        log.Fatal("查询失败!")    
    }
    if _,err := tx.Exec("INSERT INTO user0(id,server_ip,server_port) VALUES(?,?,?)",2,"192.168.0.0",9090);err != nil{
         tx.Rollback()//事务回滚
         log.Fatal("插入数据失败:",err)    
    }
    //关闭
    if err := tx.Commit();err != nil{
        tx.Rollback()//事务回滚
        log.Fatal("关闭失败:",err)    
    }
    
}
相关推荐
Databend3 分钟前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence3 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
先吃饱再说20 小时前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils21 小时前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend1 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶1 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung1 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql
parade岁月1 天前
MySQL JOIN解析:朴实无华但食之有味
数据库·后端
用户3169353811831 天前
MySQL服务无法启动问题解决全记录
数据库
vivo互联网技术1 天前
从 10 分钟到 1 秒:ES 深度分页任意跳页的三轮优化实战
服务器·数据库·redis·elasticsearch·深度分页