复杂的SELECT IN在Oracle 11中不起作用

时间:2015-03-17 16:01:01

标签: sql oracle

我有这个问题:

SELECT d.CREATION_DATE, r.RN5, s.rn1, s.PI1, r.KTR,
       VERSION_NR, getTitle(r.RN5, VERSION_NR) AS TITLE
FROM DOI_SNAPSHOT d, RELATION r, SOURCE_ADDRESS s 
WHERE r.RN1 NOT IN (8010,777) 
    AND d.RN5 = r.RN5 
    AND r.RN1 = s.RN1 
    AND r.RN5 IN (91010008,91010015)
    AND r.RN5 not in (
        SELECT RN5
        FROM RELATION
        WHERE DOI5 IS NOT NULL 
            AND DOI_DATE IS NULL
    ) 
    AND VERSION_NR = (
        SELECT max(VERSION_NR)
        FROM DOI_SNAPSHOT dmax 
        WHERE d.RN5 = dmax.RN5
    );

和这个查询:

SELECT substr(w.message, 5, instr(w.message, 'KTR') - 5) AS RN5
FROM WEB_STATISTICS w 
WHERE w.ACTION = 'DOI Display'
GROUP BY substr(w.message, 5, instr(w.message, 'KTR') - 5)
ORDER BY count(*) DESC;

他们两个都正常工作。

现在,如果我替换第一个查询的行

AND r.RN5 IN (91010008, 91010015)

并在括号中输入第二个查询,我收到错误

ORA-00907: missing right parenthesis
00907. 00000 -  "missing right parenthesis"

我不知道发生了什么,因为两个查询都在工作oracle应该至少接受语法?

2 个答案:

答案 0 :(得分:3)

问题是你在第二个查询中有一个order by子句,当你把它变成一个子查询时,你就把它留在了。该子句在该上下文中无效且无论如何都没有意义 - 您正在寻找一个集合的成员,该集合中元素的排序是无关紧要的 - 因此您应该删除order by count(*) desc部分。

用一个简单但非常人为的例子来证明;使用order by子句:

select * from dual
where dummy in (select 'X' from dual order by 1 desc);

SQL Error: ORA-00907: missing right parenthesis
00907. 00000 -  "missing right parenthesis"

没有:

select * from dual
where dummy in (select 'X' from dual);

DUMMY
-----
X    

作为错误消息的简单解释,当解析器看到它认为适用于主查询的order by时,因此子查询应该已经终止了一个右括号 - 这是缺失的。 / p>

这是一条消息,通常并不意味着您可能认为它意味着什么 - 并不是说​​查询总体上有不平衡的括号,只是发现了一个语法错误,可能是由于丢失或错位的错误造成的

答案 1 :(得分:3)

通常错误ORA-00907通常表示“在此点之前某处存在语法错误”。

我们试试

SQL> select * from dual
  2  where dummy in (select dummy from dual);

DUMMY
-----
X

SQL> select * from dual
  2  where dummy in (select dummy from dual order by 1);

ORA-00907: missing right parenthesis

所以你应该从内部查询中删除ORDER BY子句。