搜尋
首頁資料庫mysql教程Oracle数据库分页

之前没有接触过oracle数据库,一直使用的都是MSSQL,说起这两种数据库的SQL语句,有很多地方都是不一样的,具体的我也说不清促,

之前没有接触过Oracle数据库,一直使用的都是MSSQL,说起这两种数据库的SQL语句,有很多地方都是不一样的,具体的我也说不清促,大牛些比我更加清楚的。这里我只是想写一下关于在Oracle内如何实现分页的语句,便于后期自己查看。

开始在接触到项目的时候,已经有同事做了页面数据绑定的工作,当时是每刷新页面的时候将数据库对应表内记录全部查询出来,然后通过PageSize来和当前页来截取数据,绑定到页面上。我看后觉得这样效率太低了,数据量小的情况还是可以,但是一旦数据量上了十万、百万的,那样读取数据将会很慢。后来我果断采用了数据库分页的形式,有一点觉得oracle很不错的地方就是其内有着Rownum属性,嘿嘿,这下可好了,避免了再次构造rownum的麻烦。

由于对oracle内的rownum不熟悉,前期搞了几个笑话。我的想法如下:

select  *  from  tablename where rownum = 1;  //能够正确读取数据

select  *  from tablename where rownum = 10; //获取不到任何数据,但是也不报错

后来就开始查找关于oracle内rownum属性的相关资料,哎,原来rownum在插入记录的时候就已经分配好了,而且对于没有指定别名的情况下其索引值每次都得从1开始。 所以上面第二种情况下是获取不到数据的。我们在写SQL的时候避免不了有排序的要求,排序后如何能够保证rownum也是递增顺序呢?

select * from tablename where rownum = 1 order by  ordername desc; //这样获取出来的rownum将不会连贯,后来查阅和尝试可以在排序字段内加入表的主键,,那么就会先排序,然后在在递增方式赋予rownum。

重点说说分页的SQL如下:

select * from (select rownum r ,t1.* from tablename t1 where rownum

where r > StartRownum;

我也看到很多这样的SQL语句:

select * from (select rownum r,t1.* from tablename t1)

where r StartRownum;

我不得不说这种SQL的执行效率会很低的,内部SQL还是全表过滤了一遍的,太多就不说了。

linux

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
在MySQL中使用視圖的局限性是什麼?在MySQL中使用視圖的局限性是什麼?May 14, 2025 am 12:10 AM

mysqlviewshavelimitations:1)他們不使用Supportallsqloperations,限制DatamanipulationThroughViewSwithJoinsOrsubqueries.2)他們canimpactperformance,尤其是withcomplexcomplexclexeriesorlargedatasets.3)

確保您的MySQL數據庫:添加用戶並授予特權確保您的MySQL數據庫:添加用戶並授予特權May 14, 2025 am 12:09 AM

porthusermanagementinmysqliscialforenhancingsEcurityAndsingsmenting效率databaseoperation.1)usecReateusertoAddusers,指定connectionsourcewith@'localhost'or@'%'。

哪些因素會影響我可以在MySQL中使用的觸發器數量?哪些因素會影響我可以在MySQL中使用的觸發器數量?May 14, 2025 am 12:08 AM

mysqldoes notimposeahardlimitontriggers,butacticalfactorsdeterminetheireffactective:1)serverConfiguration impactactStriggerGermanagement; 2)複雜的TriggerSincreaseSySystemsystem load; 3)largertablesslowtriggerperfermance; 4)highConconcConcrencerCancancancancanceTigrignecentign; 5); 5)

mysql:存儲斑點安全嗎?mysql:存儲斑點安全嗎?May 14, 2025 am 12:07 AM

Yes,it'ssafetostoreBLOBdatainMySQL,butconsiderthesefactors:1)StorageSpace:BLOBscanconsumesignificantspace,potentiallyincreasingcostsandslowingperformance.2)Performance:LargerrowsizesduetoBLOBsmayslowdownqueries.3)BackupandRecovery:Theseprocessescanbe

mySQL:通過PHP Web界面添加用戶mySQL:通過PHP Web界面添加用戶May 14, 2025 am 12:04 AM

通過PHP網頁界面添加MySQL用戶可以使用MySQLi擴展。步驟如下:1.連接MySQL數據庫,使用MySQLi擴展。 2.創建用戶,使用CREATEUSER語句,並使用PASSWORD()函數加密密碼。 3.防止SQL注入,使用mysqli_real_escape_string()函數處理用戶輸入。 4.為新用戶分配權限,使用GRANT語句。

mysql:blob和其他無-SQL存儲,有什麼區別?mysql:blob和其他無-SQL存儲,有什麼區別?May 13, 2025 am 12:14 AM

mysql'sblobissuitableForStoringBinaryDataWithInareLationalDatabase,而ilenosqloptionslikemongodb,redis和calablesolutionsolutionsolutionsoluntionsoluntionsolundortionsolunsonstructureddata.blobobobissimplobisslowdeperformberbutslowderformandperformancewithlararengedata;

mySQL添加用戶:語法,選項和安全性最佳實踐mySQL添加用戶:語法,選項和安全性最佳實踐May 13, 2025 am 12:12 AM

toaddauserinmysql,使用:createUser'username'@'host'Indessify'password'; there'showtodoitsecurely:1)choosethehostcarecarefullytocon trolaccess.2)setResourcelimitswithoptionslikemax_queries_per_hour.3)usestrong,iniquepasswords.4)Enforcessl/tlsconnectionswith

MySQL:如何避免字符串數據類型常見錯誤?MySQL:如何避免字符串數據類型常見錯誤?May 13, 2025 am 12:09 AM

toAvoidCommonMistakeswithStringDatatatPesInMysQl,CloseStringTypenuances,chosethirtightType,andManageEngencodingAndCollat​​ionsEttingSefectery.1)usecharforfixed lengengtrings,varchar forvariable-varchar forbariaible length,andtext/blobforlargerdataa.2 seterters seterters seterters

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。