php mssql 数据库分页SQL语句

 2025-01-16  阅读 402  评论 8  点赞 399

摘要:我们在编写mis系统和web应用程序等系统时,都涉及到与数据库的交互,如果数据库中数据量很大的话,一次检索所有的记录,会占用系统很大的资源,因此我们常常采用,需要多少数据就只从数据库中取多少条记录,即采用分页语句。根据自己使用过的内容,把常见数据库sql server,or
我们在编写mis系统和web应用程序等系统时,都涉及到与数据库的交互,如果数据库中数据量很大的话,一次检索所有的记录,会占用系统很大的资源,因此我们常常采用,需要多少数据就只从数据库中取多少条记录,即采用分页语句。根据自己使用过的内容,把常见数据库sql server,oracle和mysql的分页语句,从数据库表中的第m条数据开始取n条记录的语句总结如下:
  sql server
  从数据库表中的第m条记录开始取n条记录,利用top关键字:注意如果select语句中既有top,又有order by,则是从排序好的结果集中选择:
  select *
  from ( select top n *
  from (select top (m + n - 1) * from 表名称 order by 主键 desc) t1 ) t2
  order by 主键 asc
实例:
select * from ( select top pagesize * from ( select top pagesize*cureentpage * from user_table order by id asc ) as asystable order by id desc ) as bsystable order by id asc
  例如从表sys_option(主键为sys_id)中从10条记录还是检索20条记录,语句如下:
  select *
  from ( select top 20 *
  from (select top 29 * from sys_option order by sys_id desc) t1) t2
  order by sys_id asc
  oralce数据库
  从数据库表中第m条记录开始检索n条记录
  select *
  from (select rownum r,t1.* from 表名称 t1 where rownum < m + n) t2
  where t2.r >= m
  例如从表sys_option(主键为sys_id)中从10条记录还是检索20条记录,语句如下:
  select *
  from (select rownum r,t1.* from sys_option where rownum < 30 ) t2
  where t2.r >= 10
  mysql数据库
  my sql数据库最简单,是利用mysql的limit函数,limit [offset,] rows从数据库表中m条记录开始检索n条记录的语句为:
  select * from 表名称 limit m,n
  例如从表sys_option(主键为sys_id)中从10条记录还是检索20条记录,语句如下:
  select * from sys_option limit 10,20

标签:phpphp教程

评论列表:

  •   weihang666
     发布于 4天前回复该评论
  • 写的很不错,学到了!
显示更多评论

发表评论:

管理员

承接各种程序开发,外贸网站代运营,外贸网站建设等项目
  • 内容2460
  • 积分67666
  • 金币86666

Copyright © 2024 LS'Blog-保定PHP程序员老宋个人博客 Inc. 保留所有权利。 Powered by LS'blog 3.0.3

页面耗时0.0274秒, 内存占用1.94 MB, 访问数据库29次

冀ICP备19034377号