zoukankan      html  css  js  c++  java
  • 关于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()在包含排序从句后是先排序再计算行号码。

  • 相关阅读:
    Spring的声明试事务
    spring-AOP-添加日志
    弹窗插件
    工厂设计模式
    smartUpload组件批量下载
    简单的C++委托 —— 用模板类实现类成员函数的回调
    偷Microsoft师学MFC艺:且看C++如何支持反射
    C++中回调(CallBack)的使用方法
    epoll 使用实例
    C++成员函数指针的应用
  • 原文地址:https://www.cnblogs.com/bjchaofan/p/9665744.html
Copyright © 2011-2022 走看看