添加关联时出现的错误1

PS C:\Users\Administrator\Desktop\04作业\day4> python manage.py makemigrations

Traceback (most recent call last):

File "manage.py", line 15, in

execute_from_command_line(sys.argv)

File "D:\Program Files\Python36\lib\site-packages\django-2.0.6-py3.6.egg\django\core\management\__init__.py", line 371, in ex

ecute_from_command_line

utility.execute()

File "D:\Program Files\Python36\lib\site-packages\django-2.0.6-py3.6.egg\django\core\management\__init__.py", line 347, in ex

ecute

django.setup()

File "D:\Program Files\Python36\lib\site-packages\django-2.0.6-py3.6.egg\django\__init__.py", line 24, in setup

apps.populate(settings.INSTALLED_APPS)

File "D:\Program Files\Python36\lib\site-packages\django-2.0.6-py3.6.egg\django\apps\registry.py", line 112, in populate

app_config.import_models()

File "D:\Program Files\Python36\lib\site-packages\django-2.0.6-py3.6.egg\django\apps\config.py", line 198, in import_models

self.models_module = import_module(models_module_name)

File "D:\Program Files\Python36\lib\importlib\__init__.py", line 126, in import_module

return _bootstrap._gcd_import(name[level:], package, level)

File "", line 994, in _gcd_import

File "", line 971, in _find_and_load

File "", line 955, in _find_and_load_unlocked

File "", line 665, in _load_unlocked

File "", line 678, in exec_module

File "", line 219, in _call_with_frames_removed

File "C:\Users\Administrator\Desktop\04作业\day4\index\models.py", line 53, in

class Wife(models.Model):

File "C:\Users\Administrator\Desktop\04作业\day4\index\models.py", line 57, in Wife

author = models.OneToOneField(Author,null=True)

TypeError: __init__() missing 1 required positional argument: 'on_delete'

添加关联时出现的错误2

PS C:\Users\Administrator\Desktop\04作业\day4> python manage.py makemigrations

You are trying to change the nullable field 'author' on wife to non-nullable 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) Ignore for now, and let me handle existing rows with NULL myself (e.g. because you added a RunPython or RunSQL operation to

handle NULL values in a previous data migration)

3) Quit, and let me add a default in models.py

Select an option:

解决方法:

author = models.OneToOneField(Author,null=True,on_delete=models.CASCADE)

错误1原因:

在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就可以了。

错误2原因

添加属性的时候没有为属性设置默认值,也没有设置允许为空,这里将属性值内容设置null=True,允许为空

问题解决

django添加mysql数据库_Django添加mysql数据库关联时出现的错误相关推荐

  1. django安装mysql驱动_django安装mysql驱动

    django目前支持三种mysql驱动来进行mysql的链接MySQLdb is a native driver that has been developed and supported for o ...

  2. mysql_real_connect段错误,mysql的多线程安全问题:在mysql_real_connect时出现段错误。...

    问题简化重现 19 #include 20 #include 21 22 void* func(void* arg) 23 { 24 MYSQL* mysql = (MYSQL *)arg; 26 m ...

  3. mt5 mysql数据库_Django -- 使用MySql数据库

    Django默认使用的sqlite3,这在实际的生产环境中是不推荐的: 1. 创建数据库 Linux VM_0_15_centos 3.10.0-693.el7.x86_64 #1 SMP Tue A ...

  4. django使用mysql事务处理_Django中MySQL事务的使用

    Django中事物的使用 from django.db import transaction @transaction.atomic 通过transaction的@transaction.atomic ...

  5. django使用mysql 好处_Django使用MySQL

    说明:这是在python3.6.8+Django2.2的环境下的MySQL的使用 首先是去MySQL客户端去创建数据库,默认数据集设置为utf8 CREATE DATABASE IF NOT EXIS ...

  6. mysql 1455_关于Oracle 11g导出数据时 报 ORA-1455错误的处理

    关于Oracle 11g导出数据时 报 ORA-1455错误的处理,由于导出的该用户的表可能存在空数据表,那么可能就会出现此其异常. 关于Oracle 11g导出数据时 报 ORA-1455错误的处理 ...

  7. mysql django构架图_Django框架之数据库ORM框架

    首先,我来介绍一下什么是ORM框架: O是object,也就类对象的意思,R是relation,翻译成中文是关系,也就是关系数据库中数据表的意思,M是mapping,是映射的意思.在ORM框架中,它帮 ...

  8. django连接mysql数据库_Django学习笔记(4)——Django连接数据库

    前言 在MVC或者MTV设计模式中,模型(M)代表对数据库的操作.那么如何操作数据库呢?本小节就认真学习一下.首先复习一下Django的整个实现流程 ,然后再实现一下使用数据库的整个流程,最后学习一下 ...

  9. django2 mysql驱动_Django框架学习(二)Django连接Mysql数据库,实现表的增删改查

    创建一个Django项目 方法: 1.使用 django-admin.py 管理工具来创建项目 2.用Pycharm专业版可以直接创建Django 项目 我直接用Pycharm创建的项目,比较简单,也 ...

最新文章

  1. C++ main函数中参数argc和argv含义及用法( argument count和 argument vector)
  2. 搜索引擎大调整:百度出“惊雷算法”后360搜索又将上线“八戒算法”
  3. 职业高中高一计算机的基本知识,职业高中计算机论文
  4. 【Java网络编程(二)】UDP案例——在线咨询
  5. 困计算机无法启动adb,win7系统无法启动adb.exe工具包的解决方法
  6. # 异运算_人教版六年级数学下册第29课数的运算(P7680)图文视频辅导
  7. 今天给一份 2022 互联网就业指南。
  8. 内联函数的常识性问题
  9. 使用正则test方法遇到的问题
  10. Linux 操作系统课程设计
  11. CorelDRAW2021序列号 专业的矢量图像设计软件
  12. 安装window10出错:选中的磁盘具有 MBR 分区表。在 EFI 系统上,Windows只能安装到GPT磁盘。
  13. rocketmq双主双从----四台服务器
  14. Bootstrap系列之工具提示框(Tooltips)
  15. globalThis is not defined 解决方案
  16. android 手指滑动顺时针逆时针判断
  17. 计算机机房前端,(前端机房试题.doc
  18. ubuntu unity 3D桌面效果
  19. 苹果手机科学计算机怎样调用,iOS上的表达式科学计算器Calculator i++使用说明
  20. 安装Adobe全家桶时出现The installation cannot continue as the installer file may be damaged.解决方法。

热门文章

  1. synchronized锁的升级
  2. 循环结构_do-while循环
  3. 单继承-继承的传递性
  4. ZooKeeper与Eureka的区别
  5. SpringCloud_Sell.sql
  6. Oracle 存储过程入门
  7. 面向过程和面向对象的编程思想 复习原型 构造函数和实例对象和原型对象之间的关系
  8. Spring Cloud Gateway 源码解析(1) —— 基础
  9. Java基础IO流(五)RandomAccessFile
  10. Jquery.tmpl