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")
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」