外键 gorm 的标签,引用主表
短信预约 -IT技能 免费直播动态提醒
“纵有疾风来,人生不言弃”,这句话送给正在学习Golang的朋友们,也希望在阅读本文《外键 gorm 的标签,引用主表》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新Golang相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!
问题内容有主表: 用户
create table users(
id bigserial primary key
有一个从属表:
create table users_history:
...
foreign key(user_id)
references users(id) on update cascade on delete cascade
如何定义外键和引用的 gorm 标签,并限制更新删除?
我只理解(可能,有错误):
UserID uint64 `gorm:"column:user_id; type: bigint; gorm:"constraint:OnUpdate:CASCADE,OnDelete:CASCADE;"`
解决方案
docs on HasMany relationships and foreign key constraints应该可以帮助你。
- 使用外键字段
UserID
创建一个UserHistory
结构,不需要任何标签。- 由于您命名表的方式,您需要向此模型添加一个
TableName() string
函数,该函数返回"users_history"
(默认情况下,gorm 会使用user_histories
)
- 由于您命名表的方式,您需要向此模型添加一个
- 使用
ID
字段创建User
结构体- 在此结构中添加一个
[]UserHistory
字段,并将其命名为合理的名称,例如History
。这是约束标签所在的位置gorm:"constraint:OnUpdate:CASCADE,OnDelete:CASCADE;"
- 在此结构中添加一个
就是这样。
今天关于《外键 gorm 的标签,引用主表》的内容介绍就到此结束,如果有什么疑问或者建议,可以在编程网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341