django-模型类的修改-外键

》修改模型类

如果对表的需求有变化

需要修改表

直接改模型类

》 当前需求

给一个表添加一个外键,使两张表之间发生关联

图书表,英雄表

图书与英雄的关系

1个图书对应多个英雄

1个英雄对应一个图书

因此,图书与英雄的关系是 1图书对多英雄,属于一对多关系

表格添加外键字段

》外键字段要定义在多方

》外键字段的定义方式

在模型类中定义一个字段

bid = models.ForeignKey("要关联的模型类名称")

当模型类发生变化后

1,生成迁移文件,因为sql语句肯定要重写

2,迁移数据

》迁移时发生报错

在这里插入图片描述

》解决办法

原因:

在django2.0后,定义外键和一对一关系的时候需要加on_delete选项,此参数为了避免两个表里的数据不一致问题,不然会报错:
TypeError: __init__() missing 1 required positional argument: 'on_delete'
举例说明:
user=models.OneToOneField(User)
owner=models.ForeignKey(UserProfile)
需要改成:
user=models.OneToOneField(User,on_delete=models.CASCADE) --在老版本这个参数(models.CASCADE)是默认值
owner=models.ForeignKey(UserProfile,on_delete=models.CASCADE) --在老版本这个参数(models.CASCADE)是默认值
参数说明:
on_delete有CASCADE、PROTECT、SET_NULL、SET_DEFAULT、SET()五个可选择的值
CASCADE:此值设置,是级联删除。
PROTECT:此值设置,是会报完整性错误。
SET_NULL:此值设置,会把外键设置为null,前提是允许为null。
SET_DEFAULT:此值设置,会把设置为外键的默认值。
SET():此值设置,会调用外面的值,可以是一个函数。
一般情况下使用CASCADE就可以了。

》修改表时会弹出提示

对于新增加的字段如何处理

(base) G:\bookHeroPro>python manage.py makemigrations
You are trying to add a non-nullable field 'bid' to hero without a default; we can't do that (the database needs something
 to populate existing rows).
Please select a fix:
 1) Provide a one-off default now (will be set on all existing rows with a null value for this column)
 2) Quit, and let me add a default in models.py
Select an option:

选择2,自己给外键字段添加默认值

在这里插入图片描述

正向查找与反向查找

》获取一个英雄

在这里插入图片描述

在这里插入图片描述

In [1]: from bookTest import models

In [2]: # 查找一个英雄

In [3]: heroLB = models.Hero.objects.get(id=1)

In [4]: heroLB
Out[4]: <Hero: Hero object (1)>

In [5]: heroLB.id
Out[5]: 1

In [6]: heroLB.name
Out[6]: '刘备'

In [7]: heroLB.bid_id
Out[7]: 1

In [8]: heroLB.bid
Out[8]: <Book: 三国演义>

In [9]: heroLB.bid.title
Out[9]: '三国演义'

In [10]: heroLB.bid.info
Out[10]: '三国时期的故事'

In [11]: 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鲸鱼编程pyhui

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值