今天遇到一個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函數也是很清楚怎么寫的,所以本博客之后記錄當做經驗記錄,當然這不是最好的方法