【问题标题】:Django Subquery, ORA-00904: invalid identifierDjango 子查询,ORA-00904:无效标识符
【发布时间】:2019-06-21 20:05:23
【问题描述】:

下面的查询作为原始 sql 工作

SELECT WORK_ORDER.*,(SELECT COMPLETE FROM SAMPLE WHERE COMPLETE = 'TRUE' AND
ARF_ID = WORK_ORDER.ARF_ID AND ROWNUM <= 1) AS SAMPLE_COMPLETE, (DUE_DATE - 
SYSDATE) AS DUE_IN FROM WORK_ORDER WHERE COMPLETE = 'FALSE' ORDER BY 
DUE_DATE ASC  

以下 Django 查询集不起作用

subquery = Sample.objects.filter(complete = 'TRUE', arf_id = models.OuterRef('arf_id'))[:1]
workOrderList = WorkOrder.objects.annotate(sample_complete= models.Subquery(subquery.values('complete'))).annotate(due_in= models.F('due_date') - datetime.now()).filter(complete = 'FALSE').order_by('due_date')   

在运行 workOrderList.query 时产生这个查询

SELECT "WORK_ORDER"."ARF_ID", "WORK_ORDER"."COMPANY_NAME", 
"WORK_ORDER"."COMPANY_ADDRESS", "WORK_ORDER"."CONTACT_TELEPHONE", 
"WORK_ORDER"."ORDER_DATE", "WORK_ORDER"."DUE_DATE", 
"WORK_ORDER"."ARF_NUMBER", "WORK_ORDER"."COMPLETE", 
"WORK_ORDER"."COMPLETE_DATE", "WORK_ORDER"."REPORTED", 
"WORK_ORDER"."REPORTED_DATE", "WORK_ORDER"."COMPANY_CODE", (SELECT * FROM 
(SELECT "_SUB".* FROM (SELECT U0."COMPLETE" AS Col1 FROM "SAMPLE" U0 WHERE 
(U0."COMPLETE" = TRUE AND U0."ARF_ID" = ("WORK_ORDER"."ARF_ID"))) "_SUB" 
WHERE ROWNUM <= 1)) AS "SAMPLE_COMPLETE", ("WORK_ORDER"."DUE_DATE" - 2019- 
01-28 13:00:51.043013) AS "DUE_IN" FROM "WORK_ORDER" WHERE 
"WORK_ORDER"."COMPLETE" = FALSE ORDER BY "WORK_ORDER"."DUE_DATE" ASC

这会返回错误
cx_Oracle.DatabaseError: ORA-00904: "WORK_ORDER"."ARF_ID": invalid identifier

我使用的是 Django 1.11.13,这是一个遗留数据库,我很喜欢使用原始 sql 来查询数据,但想以正确的方式学习/使用 Django ORM,所以任何修复或解释为什么这不起作用对我有帮助。

【问题讨论】:

  • Django 使用多个嵌套子查询,如果您在嵌套子查询中引用外部查询中的字段,这显然不起作用,参见。 stackoverflow.com/questions/21580705/… – 我不确定如何最好地重新编写 Django 查询。

标签: python sql django oracle django-models


【解决方案1】:

在这种情况下使用 Exists() 子类是实现总体目标的解决方案:

workOrderList = WorkOrder.objects.annotate(sample_complete= models.Exists(subquery.values('complete')))
.annotate(due_in= models.F('due_date') - datetime.now()).filter(complete = 'FALSE').order_by('due_date')

我仍在寻找使用 Subquery() 方法的解决方案

【讨论】:

    猜你喜欢
    • 2014-03-02
    • 1970-01-01
    • 2023-01-12
    • 1970-01-01
    • 1970-01-01
    • 2010-12-20
    • 2022-09-30
    • 1970-01-01
    • 2021-08-08
    相关资源
    最近更新 更多