PostgreSQL 分頁(yè)查詢時(shí)間的2種比較方法小結(jié)
數(shù)據(jù)庫(kù)中存了3000W條數(shù)據(jù),兩種分頁(yè)查詢測(cè)試時(shí)間
第一種
SELECT * FROM test_table WHERE i_id> 1000 limit 100;
Time: 0.016s
第二種
SELECT * FROM test_table limit 100 OFFSET 1000;
Time: 0.003s
第一種
SELECT * FROM test_table WHERE i_id> 10000 limit 100;
Time: 0.004s
第二種
SELECT * FROM test_table limit 100 OFFSET 10000;
Time: 0.508s
第一種:
SELECT * FROM test_table WHERE i_id> 100000 limit 100;
Time: 0.003s
第二種:
SELECT * FROM test_table limit 100 OFFSET 100000; Time: 2.377s SELECT * FROM test_table WHERE c_act='登錄' limit 100 OFFSET 100000; Time: 3.649s
第一種:
SELECT * FROM test_table WHERE i_id> 1000000 limit 100;
Time: 0.004s
第二種:
SELECT * FROM test_table limit 100 OFFSET 1000000;
Time: 14.403s
第一種:
SELECT * FROM test_table WHERE i_id> 10000000 limit 100;
Time: 0.057s
第二種:
失去等待出來結(jié)果的耐心?。?!
建議使用第一種分頁(yè)方法~
補(bǔ)充:postgreSQL數(shù)據(jù)庫(kù)limit分頁(yè)、排序
limit分頁(yè)語(yǔ)法:
select * from persons limit A offset B;
解釋:
A就是你需要顯示多少行;
B就是查詢的起點(diǎn)位置。
示例:
select * from persons limit 5 offset 0 ;
意思是,起點(diǎn)0開始查詢,返回5條數(shù)據(jù)。
select * from persons limit 15 offset 5 ;
意思是,起點(diǎn)5開始查詢,返回15條數(shù)據(jù)。
特殊:
select * from persons limit 5 ;
這個(gè)就類似:
select * from persons limit 5 offset 0;
也就是,從起點(diǎn)0開始查詢,返回5條數(shù)據(jù)。
按規(guī)則排序,同時(shí)也要分頁(yè):
select * from persons order by lastname limit 5 offset 0;
分頁(yè)并顯示行號(hào),類似oracle里的rownum:
select *,row_number() over() as rownum from persons limit 5 offset 0;
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
用PostgreSQL數(shù)據(jù)庫(kù)做地理位置app應(yīng)用
項(xiàng)目中用到了postgreSQL中的earthdistance()函數(shù)功能計(jì)算地球上兩點(diǎn)之間的距離,中文的資料太少了,我找到了一篇 英文的、講的很好的文章,特此翻譯,希望能夠幫助到以后用到earthdistance的同學(xué)2014-03-03基于postgresql數(shù)據(jù)庫(kù)鎖表問題的解決
這篇文章主要介紹了基于postgresql數(shù)據(jù)庫(kù)鎖表問題的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-12-12Abp.NHibernate連接PostgreSQl數(shù)據(jù)庫(kù)的方法
這篇文章主要為大家詳細(xì)介紹了Abp.NHibernate連接PostgreSQl數(shù)據(jù)庫(kù)的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01postgresql 查詢集合結(jié)果用逗號(hào)分隔返回字符串處理的操作
這篇文章主要介紹了postgresql 查詢集合結(jié)果用逗號(hào)分隔返回字符串處理的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-02-02postgresql 實(shí)現(xiàn)字符串分割字段轉(zhuǎn)列表查詢
這篇文章主要介紹了postgresql 實(shí)現(xiàn)字符串分割字段轉(zhuǎn)列表查詢,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-02-02在Linux系統(tǒng)上安裝PostgreSQL數(shù)據(jù)庫(kù)
這篇文章介紹了在Linux系統(tǒng)上安裝PostgreSQL數(shù)據(jù)庫(kù)的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-03-03PostgreSQL實(shí)現(xiàn)批量插入、更新與合并操作的方法
這篇文章主要給大家介紹了關(guān)于PostgreSQL實(shí)現(xiàn)批量插入、更新與合并操作的相關(guān)資料,文中通過圖文以及示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02Docker環(huán)境下升級(jí)PostgreSQL的步驟方法詳解
這篇文章主要介紹了Docker環(huán)境下升級(jí)PostgreSQL的步驟方法詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01