Django-21-ORM建表(一对多)

前言

一对多关系,是通过两张表的ID进行的关联,其中有一个表中会有相关联的另一张表的ID字段。

基于之前的user表改动,增加一个city字段;且再增加一张city表,表字段为city_name;两张表关联

 

外键创建

格式:city=models.ForeignKey("City",on_delete=models.CASCADE)

to  指向外键表(即模型类名,位置参数,to可省略不写)

to_filed 指向外键表主键(默认为表id,如果外键表自定义了id,这里为外键表定义的id)

on_delete 在django2.0后,定义外键的时候需要加on_delete选项

参数说明:
on_delete有CASCADE、PROTECT、SET_NULL、SET_DEFAULT、SET()五个可选择的值
CASCADE:此值设置,是级联删除。
PROTECT:此值设置,是会报完整性错误。
SET_NULL:此值设置,会把外键设置为null,前提是允许为null。
SET_DEFAULT:此值设置,会把设置为外键的默认值。
SET():此值设置,会调用外面的值,可以是一个函数。
一般情况下使用CASCADE就可以了。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值