ORA-01791:不是SElECTed表达式

本文详细阐述了在SQL查询中使用ORDER BY与DISTINCT关键字时遇到ORA-01791错误的原因及解决方法。通过实例分析,展示了如何在查询中正确地结合使用这些关键字,避免错误发生。
SELECT NVL(T11.DEPID, 'NULL'),
       NVL(T11.PARDEPID, 'NULL'),
       NVL(T11.DEPNAME, 'NULL')
  FROM (SELECT DISTINCT DEPID,
                        PARDEPID,
                        DEPNAME,
                        DEPCODE,
                        SPECIALTYCODE,
                        ROTAID
          FROM SYS_DEPARTMENT
         START WITH DEPID IN
                    (SELECT DEPID
                       FROM SYS_SM_ROLEDEP
                      WHERE ROLEID IN (SELECT ROLEID
                                         FROM SYS_USERQUARTERS
                                        WHERE USERID = '1'))
        CONNECT BY PARDEPID = PRIOR DEPID
         ORDER BY ORDERNO) T11

   今天在数据库执行以上代码的时候 出现“ORA-01791:不是SElECTed表达式”这个错误

   经分析,如果在ORDER BY中指定多个列,结果将先按照子句中的第一个列排序,然后第二个,依此类推
在 SELECT中未出现的列名也可用于ORDER BY 子句中,主要TABLE中有就行,但如果SELECT子句中出现了DISTINCT关键字,则只能用出现过的列名,而且如果SELECT子句中使用了任何运算符,在ORDER BY 子句中必须保持和SELECT子句中表达式完全一致,否则出现ORA-01791 ERROR

   所以将对应字段添加上就可以了

SELECT NVL(T11.DEPID, 'NULL'),
       NVL(T11.PARDEPID, 'NULL'),
       NVL(T11.DEPNAME, 'NULL')
  FROM (SELECT DISTINCT DEPID,
                        PARDEPID,
                        DEPNAME,
                        DEPCODE,
                        SPECIALTYCODE,
                        ROTAID,
                        ORDERNO
          FROM SYS_DEPARTMENT
         START WITH DEPID IN
                    (SELECT DEPID
                       FROM SYS_SM_ROLEDEP
                      WHERE ROLEID IN (SELECT ROLEID
                                         FROM SYS_USERQUARTERS
                                        WHERE USERID = '1'))
        CONNECT BY PARDEPID = PRIOR DEPID
         ORDER BY ORDERNO) T11

 

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值