希望实现select top 10 * 的功能

解决方案 »

  1.   

    这个简单,用select * from table where **=** and rownum<10即可
      

  2.   

    很简单的,楼上已经说了,昨天刚有人问过
    下面是关于rownum的介绍 
    ================================ 
    三、 Rownum和row_number() over()的使用 
    ROWNUM是oracle从8开始提供的一个伪列,是把SQL出来的结果进行编号,始终从1开始,常见的用途就是用来分页输出. 
    比如 
    SELECT * 
      FROM torderdetail a 
    WHERE ROWNUM <= 10 
    这条语句就是输出前10条纪录,在这里用途上类似于sql sever的top,不过rownum对于指定编号区间的输出应该说更强大 
    SELECT * 
      FROM (SELECT a.*, ROWNUM rn 
              FROM torderdetail a) 
    WHERE rn >= 10 AND rn <= 20 
    这条语句即是输出第10到第20条纪录,这里之所以用rownum rn,是把rownum转成实例,因为rownum本身只能用 <=的比较方式,只有转成实列,这样就可做 >=的比较了。 
    在实际用途中,常常会要求取最近的几条纪录,这就需要先对纪录进行排序后再取rownum <= 
    一般常见的 
    SELECT * 
    FROM (SELECT  a.* 
                FROM torderdetail a 
            ORDER BY order_date DESC) 
    WHERE ROWNUM <= 10 
    而在CSDN曾经发生过讨论,关于取近的10条纪录,有人给出这样的语句 
    SELECT  a.* 
        FROM torderdetail a 
      WHERE ROWNUM <= 10 
    ORDER BY order_date DESC 
    之所以会出现这样的语句,主要是从效率上的考虑,前面条语句,是要进行全表扫描后再排序,然后再取10条纪录,后一条语句则不会全表扫描,只会取出10条纪录,很明显后条语句的效率会高许多。 
    那为什么会有争议呢,那就在于在执行顺序上争议,是先执行排序取10条纪录,还是取10条纪录,再排序呢?两种顺序取出来的结果是截然相反的,先排序再取10条,就是取最近的10条,而先取10条,再排序,则取出的最早的10条纪录。对于此语句,普遍的认为执行顺序是先取10条纪录再排序的。所以此语句应该是错误。但实际上并非如此,此语句的执行顺序和order by的字段有关系,如果你order by 的字段是pk,则是先排序,再取10条(速度比第一种语句快),而排序字段不是PK 时,是先取10条再排序,此时结果就与要求不一样了,所以第二种写法一定要在排序字段是主键的情况下才能保证结果正确。 
    Row_number() over()这个分析函数是从9I开始提供的,一般的用途和rownum差不多。 
    一般写法row_number() over( order by order_date desc) 生成的顺序和rownum的语句一样,效率也一样(对于同样有order by 的rownum语句来说),所以在这种情况下两种用法是一样的。 
    而对于分组后取最近的10条纪录,则是rownum无法实现的,这时只有row_number可以实现,row_number() over(partition by 分组字段 order by 排序字段)就能实现分组后编号,比如说要取近一个月的每天最后10个订单纪录 
    SELECT * 
      FROM (SELECT a.*, 
    ROW_NUMBER () OVER (PARTITION BY TRUNC (order_date) ORDER BY order_date DESC) 
                                                                              rn 
              FROM torderdetail a) 
    WHERE rn <= 10 
    Rownum的另类用法,有时候我们会遇到这种需求,要求输出当月的所有天数,许多人会烦恼,数据库里又没有这样的表,怎么输出一个月的所有天数呢?用rownum就能解决: 
    SELECT    TRUNC (SYSDATE, 'MM') + ROWNUM - 1 
          FROM DUAL 
    CONNECT BY ROWNUM <= TO_NUMBER (TO_CHAR (LAST_DAY (SYSDATE), 'dd')) 
      

  3.   

    不过一楼的,要取10条的话,应该是rownum<=10或者rownum<11
      

  4.   

    where rownum<=n     n为你要返回的记录数目
      

  5.   

    rownum的用法应该说也有不方便的地方,
    比如如果楼主的需求是:
    经过排序的前10条,那么2楼的方法就可能得不到正确的结果了。
    这种情况只能使用子查询的方式在内循环中构建基于rownum的列,在外层查询中过滤掉大于指定行数的行。
      

  6.   

    to 2楼
    Rownum的另类用法,有时候我们会遇到这种需求,要求输出当月的所有天数,许多人会烦恼,数据库里又没有这样的表,怎么输出一个月的所有天数呢?用rownum就能解决:
    SELECT    TRUNC (SYSDATE, 'MM') + ROWNUM - 1
          FROM DUAL
    CONNECT BY ROWNUM <= TO_NUMBER (TO_CHAR (LAST_DAY (SYSDATE), 'dd')) 最后一句应该是CONNECT BY ROWNUM < TO_NUMBER (TO_CHAR (LAST_DAY (SYSDATE), 'dd')) 
      

  7.   

    oracle的联机帮助实在太难用了,很简单的问题,都查不到
      

  8.   

    你去运行下就知道,改成<会变成只到29号
    不过上次有人说好像与在服务器端还是在客户端运行有关不过我觉得没关系啊比如说6月是30天,也就是产生的rownum最多30,肯定是30天啊,写<的话,只有29天了
      

  9.   

    我也觉得没有关系,<30在那里也只应该有29条才对的。
    另外我上面的帖子把楼层写错了,应该是1楼才对。
    hebo兄,不好意思了。