django调用MySQL视图时报错 "Unknown column 'project_staff.id' in 'field list'"

django做数据库查询时需要用到视图。

视图和table相比,在django调用时有一个很大的劣势——
不能在django定义好后migrate到数据库(因为它和表在django上的定义方式没有区别,migrate会直接在数据库生成表);也不能从数据库同步到model.py(因为MySQL同步时根本不会考虑视图)。

因此只能手动在django的models.py写。

乖乖按照网上教程:
第一步,在MySQL里创建视图。创建过程就不详述了。
第二步,ango的models.py写每个视图对应的model。

然后就直接在查询时调用。

这时,
出现了一个问题。
django报错
"Unknown column 'project_staff.id' in 'field list'"

这就很奇怪了,我明明没有在任何地方定义project_staff.id,而且也没有在任何地方调用它。

难道是调用视图的教程讲得不对?我又查了好几个“django调用MySQL视图教程”,这里必须吐槽一下百度,我打开至少7个不同网页,全部是同一篇教程,连验证的图片都没有变。

最后使用谷歌大法,突然顿悟!
我没有在视图的model里定义主键!而model如果没有主键,**django会自动用自增字段id作为主键。**这是最开始用django时就了解的知识,竟然没有想起来。

划重点:
django调用MySQL时,无论是用表还是视图,在models.py里写的model一定要有主键!

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值