时间:2021-05-22
我有两个继承一个基类的Django模型:
- Request
- Inquiry
- Analysis
请求有两个外键到内置用户模型。
create_user = models.ForeignKey(User, related_name='requests_created')
assign_user = models.ForeignKey(User, related_name='requests_assigned')
由于某种原因,我得到的错误
“Analysis.assign_user”的反向访问器与“Inquiry.assign_user”的反向访问器冲突。
我读过的所有内容说,设置related_name应该防止冲突,但我仍然得到相同的错误。任何人都能想到为什么会发生这种情况?谢谢!
related_name将确保字段不会彼此冲突,但您有两个模型,每个模型都有这两个字段。你需要把每个具体模型的名字,你可以做一些特殊的 string substitution:
create_user = models.ForeignKey(User, related_name='%(class)s_requests_created')
补充知识:django related_name禁用反向映射
官方文档处理办法:
直接将related_name赋值为加号或以加号结尾的字符串,即可实现禁用反向映射
以上这篇python Django 反向访问器的外键冲突解决就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
python2.7.11django1.8.4错误内容:relatedFieldhasinvalidlookup:icontains我原来默认认为在处理外键搜索
当我们在djangoweb框架中,使用vue的时候,会遇到语法冲突.因为vue使用{{}},而django也使用{{}},因此会冲突.解决办法1:在django
今天安装Django的时候遇到了python版本冲突,找不到python路径,所以又重新安装了一个python3.6.5安装完之后,突然发现自己的pycharm
layui的table的自定义模板需要用到{{}},但是和Django的{{}}冲突了,layui的{{}}失效了解决方法:从Django1.5开始,支持{%v
django外键使用一对一因为django中处于安全和方便将数据库中的表封装成模型,所以很多sql原生的功能无法使用,比如leftjoin,但是我们可以使用外键