日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

达梦数据库分页用法

發(fā)布時間:2023/12/20 数据库 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 达梦数据库分页用法 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

達夢支持常用的分頁方式,ROWNUM(Oracle)、TOP(SQL Server)、LIMIT(MySQL)。

對于應用提供了更好的可移植性

數據準備

--創(chuàng)建學生表,id、姓名、年齡、成績

CREATE?TABLE?STU(id INT?,name varchar2(20),age int,score int);

--插入100條數據,id遞增,姓名DAMENG1遞增,年齡是13到17之前的隨機數,成績是60到100之前的隨機數

INSERT?INTO?STU SELECT?LEVEL?id,'DAMENG'||level?name,round(FLOOR(13 + (RAND()?* 5)))?age,

round(FLOOR(60 + (RAND()?* 41)))?score

FROM?DUAL ?CONNECT?BY?LEVEL<=100;

commit;

1.top

語法

<TOP 子句>::=TOP <n>

????????????????????????| <n1>,<n2>

????????????????????????| <n> PERCENT

????????????????????????| <n> WITH TIES

????????????????????????| <n> PERCENT WITH TIES

<n>::=整數(>=0)

1. TOP <n> 選擇結果的前 n 條記錄;

2. TOP <n1>,<n2> 選擇第 n1 條記錄之后的 n2 條記錄;

3. TOP <n> PERCENT 表示選擇結果的前 n%條記錄;

4. TOP <n> PERCENT WITH TIES 表示選擇結果的前 n%條記錄,同時指定結果集可以返回額外的行。額外的行是指與最后一行以相同的排序鍵排序的所有行。WITH TIES

必須與 ORDER BY 子句同時出現(xiàn),如果沒有 ORDER BY 子句,則忽略 WITH TIES。

select?top?5 * from?stu;

select?top?5,5 * from?stu;

select?top?5 percent?* from?stu;

TOP <n> PERCENT WITH TIES表示選擇結果的前 n%條記錄,同時指定結果集可以返回額外的行。額外的行是指與最后一行以相同的排序鍵排序的所有行。WITH TIES必須與 ORDER BY 子句同時出現(xiàn),如果沒有 ORDER BY 子句,則忽略 WITH TIES。

其意思就是比如查詢按照成績取前5%的學生,假如5%的學生的最后一位的成績是75,那么不在5%內的成績是75的也查詢出來。

這個有啥實際意義呢,比如我要取5%的學生評為優(yōu)秀學生,假如最后一位是98分,那其他98分的學生也評為優(yōu)秀學生。

select?top?5 percent??* from?stu order?by?score desc;

select?top?5 percent?with?ties?* from?stu order?by?score desc;

可以看到分數98的學生都查詢出來了,多了兩條記錄。

可以使用存儲過程,實現(xiàn)每次查詢多少條數據

create?or?replace?procedure?get_stuinfo(n int,m int)?as

sqlstr varchar2(500);

begin

select?top?(n-1)*m,m * from?stu;

end;

/

--需要動態(tài)執(zhí)行

create?or?replace?procedure?get_stuinfo(n int,m int)?as

sqlstr varchar2(500);

begin

sqlstr='select top '||(n-1)*m||','||m||' * from stu;';

execute?immediate?sqlstr;

end;

/

call?get_stuinfo(1,5);

2.limit

語法

<LIMIT 子句>::=<LIMIT 子句 1> | <LIMIT 子句 2>

<LIMIT 子句 1>::= ?LIMIT <記錄數>

??????????????????????????????????????????|<記錄數>,<記錄數>

??????????????????????????????????????????|<記錄數> OFFSET <偏移量>

<LIMIT 子句 2>::= OFFSET <偏移量> LIMIT <記錄數>

<記錄數>::=<整數>

<偏移量>::=<整數>

select?* from?stu limit?5;

select?* from?stu limit?5,10;

select?* from?stu limit?10 OFFSET?5;

select?* from?stu OFFSET?5 limit?10 ;

可以看到后面三條語句的查詢結果相同。

3.rownum

達夢有和oracle一樣的rownum的分頁功能。在對表進行insert時,會按照insert的順序,將rownum分配給每一行記錄,因此在select的時候,rownum的排序是根據insert記錄的順序顯示的。

select?rownum,* ?from?stu;

--可以看到rownum的順序與插入的順序是一致的。

select?rownum,* ?from?stu order?by?id desc;

--可以看到即時是倒序查詢,rownum還是不變的。

對于多表查詢或者子查詢時候,rownum是根據查詢結果動態(tài)分配的。

select?rownum,?* ?from?stu t1,stu t2 where?t1.id=t2.id;

如果查詢第一條記錄,可以使用rownum=1

select?* from?stu where?rownum?=1;

那如果查詢第二條記錄,是否可以通過rownum=2?

select?* from?stu where?rownum?=2;

可以看到沒有查詢結果。因為rownum并不是當作實體數據存放在每一張表中,而是在每一次select查詢的時候,動態(tài)分配的,有1才有2,如果rownum沒有1,那么2也就沒有了意義,所以這個查詢就不會有任何結果出來。同樣如果rownum>n 也是沒有意義的。

select?rownum,* ?from?stu where?rownum?>0;

select?rownum,* ?from?stu where?rownum?>=1;

所以也就可以理解在rownum大于0或者大于等于1的時候,查詢出來的是所有結果。同時也可以進一步想到,rownum>=n ?n是一個小于等于1的任何數,都是返回所有結果。

n甚至可以是表達式。所以如果直接使用rownum>n,rownum<m分頁是無法查詢到結果的。

所以要使用rownum進行分頁查詢,就需要使用子查詢,先將rownum查出來,把它當做表中實際的列,進行分頁。

select?* from?(select?rownum?rn,* ?from?stu)

where?rn >=1 and?rn<=5;

總結

以上是生活随笔為你收集整理的达梦数据库分页用法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。