当前位置:  数据库>oracle

MySQL、SQL Server、Oracle数据库分页查询及分析(操作手册)

    来源: 互联网  发布时间:2017-06-19

    本文导语: 1、MySQL分页查询 方式1: select * from table order by id limit m, n;   该语句的意思为,查询m+n条记录,去掉前m条,返回后n条记录。无疑该查询能够实现分页功能,但是如果m的值越大,查询的性能会越低(越后面的页数,查询性能越...

1、MySQL分页查询

方式1:

select * from table order by id limit m, n;

  该语句的意思为,查询m+n条记录,去掉前m条,返回后n条记录。无疑该查询能够实现分页功能,但是如果m的值越大,查询的性能会越低(越后面的页数,查询性能越低),因为MySQL同样需要扫描过m+n条记录。

方式2:

select * from table where id > #max_id# order by id limit n;

  该查询每次会返回n条记录,却无需像方式1扫描过m条记录,在大数据量的分页情况下,性能可以明显好于方式1,但该分页查询必须要每次查询时拿到上一次查 询(上一页)的一个最大id(或最小id)。该查询的问题就在于,我们有时没有办法拿到上一次查询(上一页)的最大id(或最小id),比如当前在第3 页,需要查询第5页的数据,该查询方法便爱莫能助了。

方式3:

  为了避免能够实现方式2不能实现的查询,就同样需要使用到limit m, n子句,为了性能,就需要将m的值尽力的小,比如当前在第3页,需要查询第5页,每页10条数据,当前第3页的最大id为#max_id#:

select * from table where id > #max_id# order by id limit 20, 10;

  其实该查询方式是部分解决了方式2的问题,但如果当前在第2页,需要查询第100页或1000页,性能仍然会较差。

方式4:

select * from table as a inner join (select id from table order by id limit m, n) as b on a.id = b.id order by a.id;

  该查询同方式1一样,m的值可能很大,但由于内部的子查询只扫描了字段id,而不是整张表,所以性能要强于方式1查询,并且该查询能够解决方式2和方式3不能解决的问题。

方式5:

select * from table where id > (select id from table order by id limit m, 1) limit n;

  该查询方式同方式4,同样通过子查询扫描字段id,效果同方式4。至于性能的话,方式5的性能会略好于方式4,因为方式5不需要在进行表的关联,而是一个简单的比较。

--------------------------------------------------------------------------------

2、SQL Server分页查询

方式1:

  假设页数是10,现在要拿出第5页的内容,查询语句如下:
  --10代表分页的大小

select top 10 *
from test
where id not in
(
 --40是这么计算出来的:10*(5-1)
 select top 40 id from test order by id
)
order by id

  原理:需要拿出数据库的第5页,就是40-50条记录。首先拿出数据库中的前40条记录的id值,然后再拿出剩余部分的前10条元素

方式2:

  还是以上面的结果为例,采用另外的一种方法
  --数据的意思和上面提及的一样

select top 10 *
from test
where id >
(
 select isnull(max(id),0)
 from
  (
  select top 40 id from test order by id
  ) A
)
order by id

  原理:先查询前40条记录,然后获得其最id值,如果id值为null的,那么就返回0,然后查询id值大于前40条记录的最大id值的记录。这个查询有一个条件,就是id必须是int类型的。

方式3:

select top 10 *
from
(
 select row_number() over(order by id) as rownumber,* from test
) A
where rownumber > 40

  原理:先把表中的所有数据都按照一个rowNumber进行排序,然后查询rownuber大于40的前十条记录
  这种方法和Oracle中的一种分页方式类似,不过只支持2005版本以上的

方式4:

  存储过程查询
   创建存储过程

alter procedure pageDemo
@pageSize int,
@page int
AS
declare @temp int
set @temp=@pageSize*(@page - 1)
begin
 select top (select @pageSize) * from test where id not in (select top (select @temp) id from test) order by id
end
执行存储过程
exec 10,5

--------------------------------------------------------------------------------

3、Oracle分页查询

方式1:

  根据ROWID来分

select * from t_xiaoxi where rowid in(select rid from (select rownum rn,rid from(select rowid rid,cid from
t_xiaoxi  order by cid desc) where rownum9980) order by cid desc;

  执行时间0.03秒

方式2:

  按分析函数来分

select * from (select t.*,row_number() over(order by cid desc) rk from t_xiaoxi t) where rk9980;

  执行时间1.01秒

方式3:

  按ROWNUM来分

select * from(select t.*,rownum rn from(select * from t_xiaoxi order by cid desc) t where rownum9980;执行时间0.1秒

  其中t_xiaoxi为表名称,cid为表的关键字段,取按CID降序排序后的第9981-9999条记录,t_xiaoxi表有70000多条记录
  个人感觉1的效率最好,3次之,2最差


    
 
 

您可能感兴趣的文章:

  • Python操作Mysql实例代码教程在线版(查询手册)
  • Mysql服务器登陆,启动,停止等基本操作命令介绍(Linux/Centos环境)
  • 我的是mandrake8.2,已经安装了mysql,请教一个菜鸟问题,怎么操作才能进入mysql,然后建库!
  • Linux和windows下用mysql c++ library操作Mysql数据库
  • 谁能推荐一个linux下的mysql的图形化操作工具?类似于mysql-front之类!!!并告诉我在哪儿可以下载??
  • php连接不上mysql但mysql命令行操作正常的解决方法
  • 怎样让我的程序能像mysql一样运行后有一个mysql>的提示符等待用户输入并解析用户输入的数据然后执行操作?
  • Python Mysql数据库操作 Perl操作Mysql数据库
  • 紧急求救!!!!如何在shell脚本中,执行对mysql的操作
  • 命令行下怎样操作MySQL
  • 如何用命令行进入mysql具体操作步骤
  • linux服务器清空MySQL的history历史记录 删除mysql操作记录
  • Thinkphp实现MySQL读写分离操作示例
  • red hat linux 7.3下一安装启动mysql服务后。热行ls操作就报错
  • 在linux下用c对mysql操作时遇到一个错误,请指点!
  • python文件读写并使用mysql批量插入示例分享(python操作mysql)
  • C++操作MySQL大量数据插入效率低下的解决方法
  • 谁知道mysql的哪个版本的jdbc驱动支持批操作,在哪儿下载?
  • MySQL 数据库跨操作系统的最快迁移方法
  • php操作mysql数据库的基本类代码
  • php中mysql连接和基本操作代码(快速测试使用,简单方便)
  • Windows环境下重置mysql密码操作命令
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • mysql database manual(mysql数据库手册)
  • MySQL DBA 常用手册小结
  • mysql Myisamchk小工具使用手册第1/2页
  • MySql官方手册学习笔记2 MySql的模糊查询和正则表达式
  • MySql官方手册学习笔记1 MySql简单上手
  • WIN2000+PHP+MYSQL+TOMCAT+JSP完全整合安装手册
  • mysql中如何查看最大连接数(max_connections)和修改最大连接数
  • 在 linux下输入"mysql"命令,进入mysql命令行,但出现“Can't connetc to local MySQL server thuough socket /var/lib/mysql/mysql.sock
  • Mysql查询错误:ERROR:no query specified原因
  • MySQL 重装MySQL后, mysql服务无法启动
  • php安装完成后如何添加mysql扩展
  • 为什么用linux安装盘安装了mysql后,启动mysql,提示找不到mysql.sock文件?
  • mysql中查询当前正在运行的SQL语句并找出mysql中运行慢的sql语句
  • 請教,在redhat linux7.2+mysql 中,系統提示mysql已啟動,網頁卻不能訪問mysql?
  • Myeclipse中自带Tomcat的JDBC连接池配置(mysql和mssql)
  • 求解释: useradd -g mysql mysql -d /home/mysql -s /sbin/nologin
  • MySQL Workbench的下载安装与使用教程
  • 在Linux内安装了Mysql,无法进入Mysql.
  • php中内置的mysql数据库连接驱动mysqlnd简介及mysqlnd的配置安装方式
  • 怎样在linux终端输入mysql直接进入mysql?
  • VS2012+MySQL+SilverLight5的MVVM开发模式介绍
  • c++中关于#include <mysql/mysql.h>的问题?
  • MySQL索引基本知识
  • mysql -u root mysql 怎么解释
  • Mysql设置查询条件(where)查询字段为NULL
  • mm.mysql那里可以下载?www.mysql.com根本下载不了。谢谢了
  • mysql中字符串和时间互相转换的方法(自动转换及DATE_FORMAT函数)
  • MySQL集群 MySQL Cluster


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3