先说明环境:Python3.6.7,Django1.9,mysqlclient1.3.13
如图,在向自定义用户表userProfile插入数据时,出现外键约束失败。所以接着查看数据库表
错误原因很明显,我们向userProfile插入数据之前,django的admin后台会自动先向django-admin-log插入一条日志记录,但此时auth_user表(系统默认表)为空,也就不会提供id字段给django_admin_user_id。
在setting.py中修改DATABASES
也就是加上了‘OPTIONS’,意思是忽略外键约束。
'OPTIONS':{
"init_command":"SET foreign_key_checks = 0;",
}
虽然解决了问题,但还是有两个疑问:1.设置忽略外键约束,数据合法性和安全性能得到保证吗?目前能想到的手段仅仅是后期在视图中加以判断;2.为什么一开始使用manage.py创建超级用户时可以成功创建