• 关于sql分页


    关于sql分页

    今天用到分页了顺便就总结了一下

    mysql 数据库:

    mysql 中有分页的关键字limit,它可以实现分页很简单;
    SELECT * FROM sys_user ORDER BY userid LIMIT startNo,total;

    startNo 是查询开始的行数,total 是要查询出多少条;

    sql server2005 数据库:
    sql server 实现分页有两种方式可以实现;
    一:利用 top 和 row_number() over(order by...)函数实现
      TOP 子句用于规定要返回的记录的数目  ,row_number()相当于伪列!
      select top total * from 
    (select *,row_number() over(order by pid) rownum from person_base )x where x.rownum>startNo
    startNo 是查询开始的行数,total 是要查询出多少条;
    需要注意的是 row_number()函数后边必须有一个排序over(order by pid)
    二:利用top 和 not in 实现
    select top total * from person_base where pid not in
    ( select top startNo pid from person_base order by pid)
    order by pid

    根据别人测试的数据显示第二种方法比第一种方法效率要高

    Oracle 数据库:
    Oracle 实现分页需要用到伪列rownum
    select * from (select *,rownum rno from person_base where rownum < = (pageNo * pageSize)) x where rno > ((pageNo - 1) * pageSize);
    pageNo 是第几页  pageSize 是每页显示的个数

    在Oracle中即有 rownum 又有row_number 但是两者是有区别的
    1.rownum的特性(没有1就不会有2,没有3……以此类推下去)决定的 rownum只能从1开始
    2.使用rownum进行排序的时候是先对结果集加入伪列rownum然后再进行排序,而函数row_number()在包含排序从句后是先排序再计算行号码。

  • 相关阅读:
    Redis安装部署
    传输方式Topic和Queue的对比
    Hudson配置及使用
    linux 绿色版 bes 6.6服务安装
    LINUX磁盘管理
    并发用户数与 TPS 之间的关系
    性能测试场景
    计算并发用户数的五种方法
    让selenium自动化脚本运行的更快的技巧
    Jmeter学习
  • 原文地址:https://www.cnblogs.com/bjchaofan/p/9665744.html
Copyright © 2020-2023  润新知