【问题标题】:SQL syntax error with "WITH" clause带有“WITH”子句的 SQL 语法错误
【发布时间】:2016-03-10 11:14:10
【问题描述】:

在 WHERE 子句中使用 WITH 别名时遇到了一个奇怪的问题。 问题SQL语句:

WITH CROOM AS (SELECT id FROM classroom WHERE floor = 1)
SELECT DISTINCT teacher_id
FROM timetable
WHERE classroom_id IN CROOM;

错误是ORA-00904: "CROOM": invalid identifier

虽然这两个语义相似的语句都很好用。

SELECT DISTINCT teacher_id
FROM timetable
WHERE classroom_id IN (SELECT id FROM classroom WHERE floor = 1);

WITH CROOM AS (SELECT id FROM classroom WHERE floor = 1)
SELECT DISTINCT T.teacher_id 
FROM timetable T JOIN CROOM ON (T.classroom_id = CROOM.id);

为什么它不能识别 WHERE 中的别名,而在 FROM 子句中接受它?

【问题讨论】:

    标签: sql oracle with-statement where-in


    【解决方案1】:

    您应该将 CROOM 用作表格。你可以写例如:

    WITH CROOM AS (SELECT id FROM classroom WHERE floor = 1)
    SELECT DISTINCT teacher_id
    FROM timetable
    WHERE classroom_id IN (select id from CROOM);
    

    【讨论】:

      猜你喜欢
      • 2017-12-22
      • 2011-05-06
      • 2016-10-22
      • 1970-01-01
      • 2014-08-17
      • 1970-01-01
      • 1970-01-01
      • 2011-08-07
      • 2017-05-18
      相关资源
      最近更新 更多