GO 批量修改 + 事务

package main

import (
"database/sql"
"fmt"
_ "github.com/go-sql-driver/mysql" // 引入你的数据库驱动
)

func main() {
// 建立数据库连接
db, err := sql.Open("mysql", "user:password@/dbname")
if err != nil {
panic(err)
}
defer db.Close()

// 确保连接可用
if err := db.Ping(); err != nil {
panic(err)
}

// 准备批量更新
tx, err := db.Begin()
if err != nil {
panic(err)
}

stmt, err := tx.Prepare("UPDATE users SET name = ? WHERE id = ?")
if err != nil {
panic(err)
}
defer stmt.Close()

// 模拟批量更新数据
names := map[int]string{
1: "Alice",
2: "Bob",
3: "Charlie",
}

for id, name := range names {
if _, err := stmt.Exec(name, id); err != nil {
tx.Rollback()
panic(err)
}
}

// 提交事务
if err := tx.Commit(); err != nil {
panic(err)
}

fmt.Println("Batch update successful")
}

posted @   minch  阅读(44)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」
点击右上角即可分享
微信分享提示