Oracle 分页和排序常用的4条查询语句

2014-11-24 17:42:14 · 作者: · 浏览: 1

  1. 查询前10条记录


  SELECT * FROM TestTable WHERE ROWNUM <= 10


  2. 查询第11到第20条记录


  SELECT * FROM (SELECT TestTable.*, ROWNUM ro FROM TestTable WHERE ROWNUM <=20) WHERE ro > 10


  3. 按照name字段升序排列后的前10条记录


  SELECT * FROM (SELECT * FROM TestTable ORDERY BY name ASC) WHERE ROWNUM <= 10


  4. 按照name字段升序排列后的第11到第20条记录


  SELECT * FROM (SELECT tt.*, ROWNUM ro FROM (SELECT * FROM TestTable ORDER BY name ASC) tt WHERE ROWNUM <=20) WHERE ro > 10


  以上此条语句可能是在查询排序和分页的时候最常用到的语句,其中没有添加条件,因为不影响语句的结构。虽然性能有所影响,但可能只是最内层的查询可能会有多查数据的可能,但对于外层的再排序再选择来说,应该影响很小。