django中对已有数据库进行query出现ORA-00904报错解决

本文探讨了在使用Django的ORM机制与Oracle数据库时遇到的ORA-00904错误,分析了错误产生的原因在于Django自动生成的模型字段与Oracle实际字段不匹配的问题。文中提供了解决方案,即通过手动指定主键来避免这一问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

情境描述:

数据库是别人给的,导入之后使用inspectdb将写入了model.py,之后再对数据库中某个表进行query的时候报错ORA-00904,“ID”,invalid identifier

 

原因分析:

由于django提供的ORM解决机制造成的,每个model至少应该有一个primary_key=True的field,但是使用inspectdb生成model的时候,并没有对每个model加入primary_key=True,导致django自动对每个model生成一个默认为“ID”的autofield

由于数据库中并没有这个“ID”,故出错。

 

解决方案:

在model中为每个主键加入primary_key=True,报错不再出现。

转载于:https://my.oschina.net/u/1032854/blog/192777

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值