对django 2.x版本中models.ForeignKey()外键说明介绍
下面是代码
class GroupInfos(models.Model): uid = models.AutoField(primary_key=True) caption = models.CharField(max_length=32, unique=True) ctime = models.DateTimeField(auto_now_add=True, null=True) uptime = models.DateTimeField(auto_now=True, null=True) class UserInfos(models.Model): username = models.CharField(max_length=32, blank=True, verbose_name='用户名') password = models.CharField(max_length=64, help_text='text') email = models.EmailField(max_length=60) user_group = models.ForeignKey('GroupInfos', to_field='uid', on_delete='CASCADE')
说明
第一个class创建一个名称为app_groupinfos的表
第二个class创建一个名称为app_userinfos的表
1、ForeignKey 表示设置外健
2、to_field表示外健关联的主键
3、on_delete有多个选项
在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就可以了。
那么,这个时候一个group就会对应多个user,属于一对多的类型。
当我们查询一个组有那些用户的时候,就会用到当前的外健,
创建记录
并且,在class中定义了foreignKey之后,group还不存在的同时,user表也因为约束的原因,不能被进行创建
删除记录
并且,在class中定义了foreignKey之后,user中记录存在的同时,group表中的记录也因为约束的原因,不能被进行删除
补充知识:owner = models.ForeignKey(User)出现TypeError
owner = models.ForeignKey(User)出现错误 TypeError: init() missing 1 required positional argument: ‘on_delete'
owner = models.ForeignKey(User)
出现下列错误:
TypeError: __init__() missing 1 required positional argument: 'on_delete'
解决办法:
owner = models.ForeignKey(User, on_delete=models.CASCADE)
以上这篇对django 2.x版本中models.ForeignKey()外键说明介绍就是小编分享给大家的全部内容了,希望能给大家一个参考
您可能感兴趣的文章:
- Django--ORM模型Field介绍及外键使用
- SequoiaDB版本在线升级介绍说明
- 【Python】django模型models的外键关联使用
- Django外键(ForeignKey)操作以及related_name的作用详解
- Django外键(ForeignKey)操作以及related_name的作用
- Docker的版本介绍说明
- Django 的 models 里的外键之一对一,一对多,多对一,多对多关系
- Django 速成笔记(3)--Django models 数据库操作-增删改查-多对多关系以及一对多(外键)关系...
- 简单介绍Python2.x版本中的cmp()方法的使用
- Python2.x版本中maketrans()方法的使用介绍
- OpenFOAM各版本说明介绍
- SequoiaDB版本在线升级介绍说明
- OpenCV2.3.1调用摄像头(OpenCV2.x版本使用介绍)
- Django 速成笔记(3)--Django models 数据库操作-增删改查-多对多关系以及一对多(外键)关系
- Django ====> 1.4版本路径设置(续)--staticfiles,STATIC_ROOT, STATIC_URL,STATICFILES_DIRS介绍
- Django之models中两个字段使用同一个外键
- django 外键在各个版本中的对比,一对多,多对多,自关联的问题
- Django2.X版本外键表插入数据主键创建失败
- Blog.objects.filter()反查外键,django数据库models中的跨表查询,相当于sql的join
- Qt+OpenCV2.3.1调用摄像头(OpenCV2.x版本使用介绍)