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()在包含排序从句后是先排序再计算行号码。

  • 相关阅读:
    HTML语言基础
    过滤器Filter
    新闻实现分页显示
    [转]Jmeter使用入门
    [转]ZK工作原理
    [转]UT-IT-ST-BBIT-SDV-SIT-SVT
    Unix编码哲学
    火星坐标、百度坐标、WGS-84坐标相互转换及墨卡托投影坐标转经纬度JavaScript版
    递归公用表表达式概述
    java写word转pdf
  • 原文地址:https://www.cnblogs.com/bjchaofan/p/9665744.html
Copyright © 2011-2022 走看看