自动创建、更新
GORM在创建或更新记录时会自动地保存其关联和引用,主要使用upsert技术来更新现有关联的外键引用。
在创建时自动保存关联
当你创建一条新的记录时,GORM会自动保存它的关联数据。 这个过程包括向关联表插入数据以及维护外键引用。
user := User{ |
通过FullSaveAssociations来更新关联
对于需要全面更新关联数据(不止外键)的情况,就应该使用 FullSaveAssociations 方法。
// 更新用户并完全更新其所有关联 |
使用FullSaveAssociations 方法来确保模型的整体状态,包括其所有关联都反映在了数据库中,从在应用中保持数据的完整性和一致性。
跳过自动创建、更新
GORM 提供了在创建或更新操作过程中跳过自动保存关联的灵活性。 通过使用Select或者Omit方法可以允许您指定具体哪些字段在操作中被包含或者排除
使用Select 来指定字段范围
Select方法可以让您模型中的哪些字段应该被保存 也就是说只有被选中的字段会被包含在SQL中
user := User{ |
使用Omit来排除字段或关联
// 创建用户时跳过字段“BillingAddress” |
注意: 对于多对多关联关系, GORM 会在创建连接表引用之前更新关联。 要跳过更新,可以使用
Omit,参数为关联名后面跟着.*
// 跳过更新"Languages"关联
db.Omit("Languages.*").Create(&user)跳过创建关联及其引用:
// 跳过创建 'Languages' 关联及其引用
db.Omit("Languages").Create(&user)
通过使用 Select 和 Omit,你能够很好地调整GORM处理创建或更新您的模型的行为,同时让您也能控制关联关系的自动保存行为
Select/Omit 关联字段
在GORM中创建或者更新记录时,可以使用Select和Omit方法来指定是否包含某个关联的字段
使用Select,你能够指定关联模型中的特定字段在保存主模型的时候是否被包含 在仅保存部分关联时这非常有用
而Omit则能够排除关联模型的特定字段。 这可能会在你想阻止关联模型的特定部分被更新时有用
user := User{ |
删除关联
GORM 能在删除主模型时使用Select方法来删除关联关系(一对一、一对多、多对多)。 在删除时维护好数据完整性并确保关联数据被妥当管理上,这项特性非常有用。
你可以用Select来指定哪些关联应该随着主模型被删除
//删除用户时,也删除用户的帐户 |
**注意:**请务必注意,仅当删除记录的主键不为零时,才会删除关联。 GORM 使用这些主键作为删除所选关联的条件。
// 这样无法实现预期效果
db.Select("Account").Where("name = ?", "jinzhu").Delete(&User{})
// SQL: 删除所有名为 'jinzhu' 的用户,但这些用户的关联账户不会被删除
// 正确删除用户及其账户的方式
db.Select("Account").Where("name = ?", "jinzhu").Delete(&User{ID: 1})
// SQL: 删除名为 'jinzhu' 且 ID 为 '1' 的用户及其关联账户
// 删除指定 ID 用户及其账户db.Select("Account").Delete(&User{ID: 1})
// SQL: 删除 ID 为 '1' 的用户及其关联账户
关联模式
GORM 中的关联模式提供了多种辅助方法来处理模型之间的关系,为管理关联数据提供了高效的方式。
要启动关联模式,您需要指定源模型和关系的字段名称。 源模型必须包含主键,并且关系的字段名称应与现有的关联字段相匹配。
var user User |
查询关联
检索关联记录,可以带有或不带有额外的条件。
// Simple find |
追加关联
为 多对多、一对多 添加新的关联,或者替换 一对一、属于 关系中的当前关联。
替换关联
用新的关联替换当前的关联。
// Replace existing languages |
删除关联
删除源模型和目标模型之间的关系,只删除引用。
// Delete specific languages |
清空关联
删除源模型和关联之间的所有引用。
// Clear all languages |
关联计数
获取当前关联的数量,可以带有或不带有条件。
// Count all languages |
批量数据处理
关联模式允许您批量处理多个记录的关系。 这包括查找、追加、替换、删除和计数操作,以便操作关联数据。
- 查找关联:检索一组记录的关联数据。
db.Model(&users).Association("Role").Find(&roles) |
- 删除关联:删除多个记录之间的特定关联。
db.Model(&users).Association("Team").Delete(&userA) |
- 计数关联:获取一批记录的关联数量。
db.Model(&users).Association("Team").Count() |
- 追加/替换关联:管理多个记录的关联。 请注意,参数的长度需要与数据匹配。
删除关联记录
In GORM, the Replace, Delete, and Clear methods in Association Mode primarily affect the foreign key references, not the associated records themselves. Understanding and managing this behavior is crucial for data integrity.
- Reference Update: These methods update the association’s foreign key to null, effectively removing the link between the source and associated models.
- No Physical Record Deletion: The actual associated records remain untouched in the database.
通过Unscoped来变更默认的删除行为
For scenarios requiring actual deletion of associated records, the Unscoped method alters this behavior.
- Soft Delete: Marks associated records as deleted (sets
deleted_atfield) without removing them from the database.
db.Model(&user).Association("Languages").Unscoped().Clear() |
- Permanent Delete: Physically deletes the association records from the database.
// db.Unscoped().Model(&user) |
GORM中的关联标签通常用于指定如何处理模型之间的关联。 这些标签定义了一些关系细节,比如外键,引用和约束。 理解这些标签对于有效地建立和管理模型之间的关系而言至关重要。
| 标签 | 描述 |
|---|---|
foreignKey |
Specifies the column name of the current model used as a foreign key in the join table. |
references |
|
polymorphic |
Defines the polymorphic type, typically the model name. |
polymorphicValue |
Sets the polymorphic value, usually the table name, if not specified otherwise. |
many2many |
Names the join table used in a many-to-many relationship. |
joinForeignKey |
|
joinReferences |
Points to the foreign key column in the join table that links to the reference model’s table. |
constraint |
为关联指定诸如 OnUpdate、OnDelete 之类的关系约束。 |