首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >复杂SELECT IN在Oracle 11中不工作

复杂SELECT IN在Oracle 11中不工作
EN

Stack Overflow用户
提问于 2015-03-17 16:01:00
回答 2查看 99关注 0票数 0

我有一个疑问:

代码语言:javascript
运行
复制
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
    );

这个问题是:

代码语言:javascript
运行
复制
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;

他们两人都工作正常。

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

代码语言:javascript
运行
复制
AND r.RN5 IN (91010008, 91010015)

在第二个查询中插入括号,我会得到一个错误

代码语言:javascript
运行
复制
ORA-00907: missing right parenthesis
00907. 00000 -  "missing right parenthesis"

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

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-03-17 16:15:22

问题是,您在第二个查询中有一个order子句,而当您将其转换为子查询时,就保留了这个子句。该子句在该上下文中无效,而且无论如何都没有意义--您正在寻找一个集合的成员,该集合中元素的排序是不相关的-所以您应该删除order by count(*) desc部件。

用一个简单但精心设计的例子演示;用order子句:

代码语言:javascript
运行
复制
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"

而且没有:

代码语言:javascript
运行
复制
select * from dual
where dummy in (select 'X' from dual);

DUMMY
-----
X    

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

这条信息通常并不意味着您可能认为它意味着什么--并不是查询总体上有不平衡的括号,而是发现了一个语法错误,该错误可能是由于丢失或放置错误引起的。

票数 3
EN

Stack Overflow用户

发布于 2015-03-17 16:17:06

一般来说,error ORA-00907通常意味着“在此之前的某个地方有语法错误”。

让我们试一下

代码语言:javascript
运行
复制
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子句。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29103930

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档