目录
GORM的CRUD教程
更新操作
更新所有字段
更新指定字段
使用 Select 和 Omit 更新
无 Hooks 更新
批量更新
删除操作
删除记录
批量删除
软删除
物理删除
示例代码
GORM的CRUD教程
CRUD 是 "Create, Read, Update, Delete"(创建、查询、更新、删除)的缩写,代表了数据库操作的基本功能。在 GORM 的上下文中,CRUD 指的是使用 GORM 库来执行这些基本的数据库操作。
更新操作
更新所有字段
使用 Save
方法可以更新对象的所有字段。
type User struct {gorm.ModelName stringAge int
}func main() {db, err := gorm.Open(/* 连接数据库的参数 */)if err != nil {log.Fatal(err)}// 假设已经从数据库中获取了用户数据var user Userdb.First(&user, "id = ?", 1)// 更新用户信息user.Name = "Bob"user.Age = 25// 保存更新db.Save(&user)
}
这段代码是使用Go语言和GORM库来操作数据库的示例。GORM是一个用于Golang的开源对象关系映射(ORM)库,它简化了与数据库的交互。
首先,定义了一个名为User
的结构体,它包含了三个字段:gorm.Model
、Name
和Age
。gorm.Model
是GORM提供的一个基础模型,包含了一些通用的字段,如创建时间、更新时间和删除时间等。
接下来,在main
函数中,首先尝试连接到数据库。这里省略了具体的连接参数,通常包括数据库类型、用户名、密码、主机地址和端口等信息。如果连接失败,程序将记录错误并退出。
然后,假设已经从数据库中获取了一个用户数据,将其存储在名为user
的变量中。这里使用了db.First
方法,它会根据给定的条件(这里是id = 1
)查询数据库中的第一条记录,并将其赋值给user
变量。
接下来,对user
变量的属性进行了修改,将其Name
属性设置为"Bob",Age
属性设置为25。
最后,使用db.Save
方法将更新后的user
对象保存回数据库。这将触发数据库的更新操作,将对应记录的Name
和Age
字段更新为新的值。
更新指定字段
使用 Update
或 Updates
方法可以更新指定字段。
// 更新单个字段
db.Model(&user).Update("age", 26)// 更新多个字段
db.Model(&user).Updates(User{Name: "Alice", Age: 30})
-
db.Model(&user).Update("age", 26)
:这行代码表示更新名为user
的对象的年龄字段为26。db.Model(&user)
表示将要操作的对象设置为user
,Update("age", 26)
表示将age
字段的值更新为26。 -
db.Model(&user).Updates(User{Name: "Alice", Age: 30})
:这行代码表示更新名为user
的对象的多个字段。db.Model(&user)
表示将要操作的对象设置为user
,Updates(User{Name: "Alice", Age: 30})
表示将user
对象的Name
字段更新为"Alice",并将Age
字段更新为30。
使用 Select 和 Omit 更新
使用 Select
和 Omit
可以控制更新哪些字段。
// 更新指定字段,忽略其他字段
db.Model(&user).Select("age").Omit("name").Update("age", 27)
db.Model(&user)
:表示将要操作的对象设置为user
。Select("age")
:表示只选择要更新的字段为age
。Omit("name")
:表示忽略name
字段,即不对该字段进行任何操作。Update("age", 27)
:表示将age
字段的值更新为27。
综合起来,这段代码的作用是将名为user
的对象的年龄字段更新为27,但不会更改其名字段的任何值。
无 Hooks 更新
使用 UpdateColumn
或 UpdateColumns
方法可以进行无 Hooks 更新。
// 更新单个字段,不触发 Hooks
db.Model(&user).UpdateColumn("age", 28)// 更新多个字段,不触发 Hooks
db.Model(&user).UpdateColumns(User{Age: 29})
这段代码是使用Go语言的GORM库来更新数据库中的记录,同时避免触发相关的钩子(Hooks)。
-
db.Model(&user).UpdateColumn("age", 28)
:这行代码表示更新名为user
的对象的年龄字段为28。db.Model(&user)
表示将要操作的对象设置为user
,UpdateColumn("age", 28)
表示将age
字段的值更新为28。与普通的Update
方法不同,UpdateColumn
不会触发任何关联的钩子函数。 -
db.Model(&user).UpdateColumns(User{Age: 29})
:这行代码表示更新名为user
的对象的多个字段。db.Model(&user)
表示将要操作的对象设置为user
,UpdateColumns(User{Age: 29})
表示将user
对象的Age
字段更新为29。同样地,与普通的Updates
方法不同,UpdateColumns
不会触发任何关联的钩子函数。
通过使用UpdateColumn
和UpdateColumns
方法,可以确保在更新数据时不会触发任何额外的钩子函数,这对于某些情况下需要更精确控制更新过程的场景非常有用。
批量更新
使用 SQL 表达式进行批量更新。
db.Table("users").Where("age > ?", 20).Update("age", gorm.Expr("age + 1"))
这段代码是使用Go语言的GORM库来更新数据库中的记录。
db.Table("users")
:表示将要操作的数据表为"users"。Where("age > ?", 20)
:表示筛选条件,只选择年龄大于20的用户。Update("age", gorm.Expr("age + 1"))
:表示将满足条件的用户的age
字段的值加1。gorm.Expr
用于构建表达式,这里使用了SQL表达式age + 1
来实现自增操作。
综合起来,这段代码的作用是将名为"users"的数据表中年龄大于20的所有用户的年龄字段值加1。
删除操作
删除记录
使用 Delete
方法删除记录时,需要确保主键字段有值。
// 删除单个记录
db.Delete(&user, "id = ?", 1)// 删除多个记录
db.Delete(&User{}, "age > ?", 20)
这段代码是使用Go语言的GORM库来删除数据库中的记录。
-
db.Delete(&user, "id = ?", 1)
:这行代码表示删除名为user
的对象中,满足条件"id = 1"的记录。&user
表示要操作的对象,"id = ?"
是SQL语句的条件部分,1
是条件的值。 -
db.Delete(&User{}, "age > ?", 20)
:这行代码表示删除所有年龄大于20的用户记录。&User{}
表示要操作的对象,这里使用了空结构体作为占位符,因为只需要指定表名和条件即可。"age > ?"
是SQL语句的条件部分,20
是条件的值。
批量删除
使用 Delete
方法可以删除多个记录。
db.Delete(&User{}, "age > ?", 20)
db.Delete(&User{}, "age > ?", 20)
:这行代码表示删除所有年龄大于20的用户记录。&User{}
表示要操作的对象,这里使用了空结构体作为占位符,因为只需要指定表名和条件即可。"age > ?"
是SQL语句的条件部分,20
是条件的值。
软删除
如果模型包含 DeletedAt
字段,GORM 会自动处理软删除。
// 软删除
db.Delete(&user, "id = ?", 1)// 查询未被软删除的记录
var users []User
db.Find(&users, "deleted_at IS NULL")
这段代码是使用Go语言的GORM库来操作数据库中的记录。
-
db.Delete(&user, "id = ?", 1)
:这行代码表示删除ID为1的用户记录。&user
表示要操作的对象,"id = ?"
是SQL语句的条件部分,1
是条件的值。这里的软删除是指将用户的deleted_at
字段设置为当前时间,而不是直接从数据库中删除记录。 -
var users []User
:这行代码声明了一个名为users
的切片,用于存储查询到的用户记录。 -
db.Find(&users, "deleted_at IS NULL")
:这行代码表示查询所有未被软删除的用户记录。&users
表示要将查询结果存储到哪个变量中,"deleted_at IS NULL"
是SQL语句的条件部分,表示只查询deleted_at
字段为NULL(即未被软删除)的记录。
物理删除
如果需要进行物理删除,可以使用 Unscoped
方法。
// 物理删除
db.Unscoped().Delete(&user, "id = ?", 1)
-
db.Unscoped()
:这个方法用于禁用软删除功能,使得后续的删除操作会直接从数据库中删除记录,而不是更新deleted_at
字段。 -
Delete(&user, "id = ?", 1)
:这行代码表示删除ID为1的用户记录。&user
表示要操作的对象,"id = ?"
是SQL语句的条件部分,1
是条件的值。这里的物理删除是指直接从数据库中删除记录,而不是将其标记为已删除。
示例代码
以下是完整的示例代码,演示如何在 GORM 中实现 CRUD 操作中的 "Update" 和 "Delete" 功能。
package mainimport ("gorm.io/driver/sqlite""gorm.io/gorm""gorm.io/gorm/logger""log"
)type User struct {gorm.ModelName stringAge int
}func main() {// 连接数据库db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{Logger: logger.Default.LogMode(logger.Info),})if err != nil {log.Fatal(err)}// 自动迁移模式db.AutoMigrate(&User{})// 创建记录user := User{Name: "Alice", Age: 30}db.Create(&user)// 更新记录user.Age = 31db.Save(&user)// 更新指定字段db.Model(&user).Update("age", 32)// 使用 Select 和 Omit 更新db.Model(&user).Select("age").Omit("name").Update("age", 33)// 无 Hooks 更新db.Model(&user).UpdateColumn("age", 34)// 批量更新db.Table("users").Where("age > ?", 20).Update("age", gorm.Expr("age + 1"))// 删除记录db.Delete(&user, "id = ?", user.ID)// 软删除db.Delete(&user, "id = ?", user.ID)// 物理删除db.Unscoped().Delete(&user, "id = ?", user.ID)
}
在这个示例中,我们首先连接到 SQLite 数据库,然后定义了一个 User
结构体,并进行了自动迁移。接着,我们创建、更新和删除了用户记录,并演示了如何进行软删除和物理删除。
期末放假自学Gin框架,希望我们可以一起学习!