Oracle 進階查詢

來源:互聯網
上載者:User

1.  隨機返回記錄

 

Select * from (select ename,job from emp order by dbms_random.value()) where rownum<=5 隨機返回五條記錄。其中用到了系統函數dbms_random.value()為隨機數

 

2.  處理空值排序

select * from emp order by comm desc nulls last;空值排在最前

select * from emp order by comm desc nulls first);空值排在最後

3.  連續求和

select ename,sal,sum(sal) over(), sum(sal) over(order by ename) from emp;

添加over()為連續求和形式。Over( [ 分區子句 ] [ 排序子句 [ 滑動視窗子句 ] ])。如果over中不加任何參數,則效果與前面的彙總函式為準,本身則沒有效果。如果有多個over則排序次序以最後一個為準。

select deptno,sal ,sum(sal) over (partition by deptno order by ename) as s from emp;分部門連續求和

按照某個欄位,去連續求和,如果該欄位的值改變了,連續求和重新開始

 

4.  得到當前資料的上一行或者下一行

lead(欄位) 得到當前資料的下一行

lag(欄位) 得到當前資料的上一行

這兩個函數一般也是配合over函數使用

select ename,sal,lead(sal) over(order by sal) aaa ,lag(sal) over(order by sal) bbb from emp;

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.