在GORM中,你可以使用Create
方法进行批量插入,使用Save
或Updates
方法进行批量更新。下面是具体的示例:
- 批量插入:
package main import ( "fmt" "gorm.io/driver/sqlite" "gorm.io/gorm" ) type User struct { ID uint Name string Age int } func main() { // 初始化数据库连接 db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{}) if err != nil { panic("failed to connect database") } // 迁移 schema db.AutoMigrate(&User{}) // 创建一个用户切片 users := []User{ {Name: "John", Age: 25}, {Name: "Jane", Age: 30}, {Name: "Tom", Age: 35}, } // 批量插入数据 result := db.Create(&users) if result.Error != nil { fmt.Println("Error occurred while bulk inserting data:", result.Error) } else { fmt.Println("Bulk insertion successful") } }
- 批量更新:
package main import ( "fmt" "gorm.io/driver/sqlite" "gorm.io/gorm" ) type User struct { ID uint Name string Age int } func main() { // 初始化数据库连接 db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{}) if err != nil { panic("failed to connect database") } // 迁移 schema db.AutoMigrate(&User{}) // 创建一个用户切片 users := []User{ {ID: 1, Name: "John", Age: 26}, {ID: 2, Name: "Jane", Age: 31}, {ID: 3, Name: "Tom", Age: 36}, } // 批量更新数据 for _, user := range users { result := db.Model(&User{}).Where("id = ?", user.ID).Updates(user) if result.Error != nil { fmt.Printf("Error occurred while updating user with ID %d: %v\n", user.ID, result.Error) } else { fmt.Printf("User with ID %d updated successfully\n", user.ID) } } }
注意:在执行批量操作时,请确保你的数据库支持批量插入和更新。例如,SQLite在默认情况下不支持批量插入,但你可以通过设置_busy_timeout
来解决这个问题。对于其他数据库,如MySQL和PostgreSQL,它们通常都支持批量操作。