几种常用数据库 分页查询的sql语句和简单分析

论坛 期权论坛 脚本     
已经匿名di用户   2022-5-29 19:38   2090   0
  1. 一、sqlserver分页
  2. 第一种分页方法
  3. 需用到的参数:
  4. pageSize 每页显示多少条数据
  5. pageNumber 页数 从客户端传来
  6. totalRecouds 表中的总记录数 select count (*) from 表名
  7. totalPages 总页数
  8. totalPages=totalRecouds%pageSize==0?totalRecouds/pageSize:totalRecouds/pageSize+1
  9. pages 计算前pages 条数据
  10. pages= pageSize*(pageNumber-1)
  11. SQL语句:
  12. select top pageSize * from 表名 where id not in (select top pages id from 表名 order by id) order by id
  13. 第二种分页方法
  14. pageSize 每页显示多少条数据
  15. pageNumber 页数 从客户端传来
  16. pages=pageSize*(pageNumber-1)+1
  17. select top pageSize * from 表名 where id>=(select max(id) from (select top pages id from 表名 order by id asc ) t )
  18. 二、mysql分页
  19. 需用到的参数:
  20. pageSize 每页显示多少条数据
  21. pageNumber 页数 从客户端传来
  22. totalRecouds 表中的总记录数 select count (*) from 表名
  23. totalPages 总页数
  24. totalPages=totalRecouds%pageSize==0?totalRecouds/pageSize:totalRecouds/pageSize+1
  25. pages 起始位置
  26. pages= pageSize*(pageNumber-1)
  27. SQL语句:
  28. select * from 表名 limit pages, pageSize;
  29. mysql 分页依赖于关键字 limit 它需两个参数:起始位置和pageSize
  30. 起始位置=页大小*(页数-1)
  31. 起始位置=pageSize*(pageNumber -1)
  32. 三、oracle分页
  33. pageSize 每页显示多少条数据
  34. pageNumber 页数 从客户端传来
  35. totalRecouds 表中的总记录数 select count (*) from 表名
  36. totalPages 总页数
  37. totalPages=totalRecouds%pageSize==0?totalRecouds/pageSize:totalRecouds/pageSize+1
  38. startPage 起始位置
  39. startPage= pageSize*(pageNumber-1)+1
  40. endPage=startPage+pageSize
  41. SQL语句
  42. select a.* from
  43. (
  44. select rownum num ,t.* from 表名 t where 某列=某值 order by id asc
  45. )a
  46. where a.num>=startPage and a.num<endPage
  47. db2分页
  48. int startPage=1 //起始页
  49. int endPage; //终止页
  50. int pageSize=5; //页大小
  51. int pageNumber=1 //请求页
  52. startPage=(pageNumber-1)*pageSize+1
  53. endPage=(startPage+pageSize);
  54. SQL语句
  55. select * from (select 字段1,字段2,字段3,字段4,字段5,rownumber() over(order by 排序字段 asc ) as rowid from 表名 )as a where a.rowid >= startPage AND a.rowid <endPage
  56. access分页
  57. pageSize 每页显示多少条数据
  58. pageNumber 页数 从客户端传来
  59. pages=pageSize*(pageNumber-1)+1
  60. SQL语句
  61. select top pageSize * from 表名 where id>=(select max(id) from (select top pages id from 表名 order by id asc ) t )
分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:81
帖子:4969
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP