Oracle報錯#“ORA-01791: 不是 SELECTed 表達式”解決方法


今天遇到一個Oracle報錯,寫篇博客記錄一下

簡單看一下下面這個sql,這也查詢是沒報錯的

select a.area_seq,
                 a.area_name
   from t_unit_area a
  WHERE area_seq='1580'
  order by a.order_num

然后加個distinct去重一下,不要經常使用distinct,因為性能不好

select distinct a.area_seq,
                 a.area_name
   from t_unit_area a
  WHERE area_seq='1580'
  order by a.order_num

再查詢一下就報錯

“ORA-01791: 不是 SELECTed 表達式”

網上也有人遇到類型的,具體原因是,加distinct關鍵字的時候,排序的字段也要查出來,所以SQL要改成如下,將a.order_num字段也查出來

select distinct a.area_seq,
                 a.area_name,
                 a.order_num
   from t_unit_area a
  WHERE area_seq='1580'
  order by a.order_num

網上很多這種情況,解決方法也類似,不過都沒給出具體原因,Oracle官方提供的distinct函數也是很清楚怎么寫的,所以本博客之后記錄當做經驗記錄,當然這不是最好的方法


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM