1、使用distinct的注意事项【 ORA-01791:不是SElECTed表达式】
select DISTINCT G.XM
FROM B01 B,A02 A,GBZHXXJ G
WHERE A.A01B=B.B11 AND G.ID=A.A00 AND CCBM>='010201' AND G.BS=1
ORDER BY B.CCBM,A.A25;
总是提示:“ORA-01791:不是SElECTed表达式”
摆弄了半天才搞明白:如果在ORDER BY中指定多个列,结果将先按照子句中的第一个列排序,然后第二个,依此类推在 SELECT中未出现的列名也可用于ORDER BY 子句中,主要TABLE中有就行,但如果SELECT子句中出现了DISTINCT关键字,则只能用出现过的列名,而且如果SELECT子句中使用了任何运算符,在ORDER BY 子句中必须保持和SELECT子句中表达式完全一致,否则出现ORA-01791 ERROR
所以,上面SQL语句改为
select DISTINCT B.CCBM,A.A25,G.XM
FROM B01 B,A02 A,GBZHXXJ G
WHERE A.A01B=B.B11 AND G.ID=A.A00 AND CCBM>='010201' AND G.BS=1
ORDER BY B.CCBM,A.A25
本文详细解析了在SQL查询中使用DISTINCT关键字时容易遇到的问题,特别是与ORDER BY子句结合使用时可能出现的ORA-01791错误。通过具体的SQL语句示例,解释了如何正确地应用DISTINCT并避免常见的错误。
508

被折叠的 条评论
为什么被折叠?



