Oracle、MySQL和SqlServe三种数据库分页查询语句的区别介绍

所属分类: 数据库 / MsSql 阅读数: 302
收藏 0 赞 0 分享

先来定义分页语句将要用到的几个参数:

int currentPage ; //当前页
int pageRecord ; //每页显示记录数

以之前的ADDRESSBOOK数据表为例(每页显示10条记录):

一、SqlServe下载 分页语句

String sql = "select top "+pageRecord +" * from addressbook where id not in (select top "+(currentPage-)*pageRecord +" id from t_user)"; 
// (currentPage-)*pageRecord : 是指从第几个记录开始 

第二页SQL演示:

select top 20 * from addressbook where id not in (select top 10 id from addressbook)

二、MySQL数据库分页语句

String sql = "select * from addressbook where limit "+(currentPage-)*pageRecord +","+pageRecord +""; 
//select * from 表名 【条件】limit M,N; 
//M为从第几个记录开始,比如每页显示条记录,第二页就必须从第条记录开始 
//N每页读几个数据 

第二页SQL演示:

select * from addressbook where limit 10,10

三、Oracle数据库分页语句

String sqls = "select * from ( select rownum rn,t.* from addressbook t where rownum <= "+currentPage*pageRecord+" ) where rownum > "+(currentPage -1)*pageRecord; 

第二页SQL演示:

select * from ( select rownum rn,t.* from addressbook where rownum<= 20 ) where rownum > 10

以上所述是小编给大家介绍的Oracle、MySQL和SqlServe三种数据库分页查询语句的区别介绍,希望对大家有所帮助!

更多精彩内容其他人还在看

sql Set IDENTITY_INSERT的用法

SET IDENTITY_INSERT 允许将显式值插入表的标识列中。
收藏 0 赞 0 分享

sql 修改表的所有者

有时候因为一些权限问题,需要修改表的所有者,下面的方法不错
收藏 0 赞 0 分享

过程需要参数 '@statement' 为 'ntext/nchar/nvarchar' 类型

过程需要参数
收藏 0 赞 0 分享

mssql 建立索引第1/2页

假设你想找到本书中的某一个句子。你可以一页一页地逐页搜索,但这会花很多时间。而通过使用本书的索引,你可以很快地找到你要搜索的主题。
收藏 0 赞 0 分享

SQL Server 索引结构及其使用(一)--深入浅出理解索引结构第1/4页

深入浅出理解索引结构
收藏 0 赞 0 分享

SQL Server 索引结构及其使用(二) 改善SQL语句第1/3页

很多人不知道SQL语句在SQL SERVER中是如何执行的,他们担心自己所写的SQL语句会被SQL SERVER误解。
收藏 0 赞 0 分享

获取MSSQL数据字典的SQL语句

获取MSSQL数据字典的实现方法。
收藏 0 赞 0 分享

Microsoft Search 服务无法启动 解决办法.

尝试用正常系统的注册表项添加到非正常系统中去。(因为对比的两个系统版本、结构相同,所此次就直接通过导入导出注册表项进行批量修改)。
收藏 0 赞 0 分享

找出所有非xml索引并重新整理的sql

找出所有非xml索引
收藏 0 赞 0 分享

SQL Server提示"选定的用户拥有对象,所以无法除去该用户”

今天在帮朋友弄一台服务器的时候当我需要删除一个数据库里的用户时,提示如下错误信息: "选定的用户拥有对象,所以无法除去该用户" 如何解决呢?
收藏 0 赞 0 分享
查看更多