在MySQL中,有时候我们要选出N条记录,希望在结果中每条记录中加上一列标记该记录是第几条。
这个问题在oracle中,用rownum就可以简单的实现,但是在MySQL中,怎么去实现呢?下面给大家举一个例子:
select t.page,t.pv,@rn:=if(1=1,@rn+1,@rn) as rn
from
(select
page,
pv
from
module_page_statis
where
statisDay=’2010-05-31′ and module=’new_info’ order by 2 desc limit 10) t, (select @rn:=0) t2
order by t.pv desc
这里略微解释下:
1,(select @rn:=0) 仅仅起到初始化的作用。
2,@rn:=if(1=1,@rn+1,@rn) 这一句是每选出一条记录出来,执行一次。当然这里面还可以填充更复杂的逻辑。
from:mysql社区



哥们,要租用服务器不?
武汉网盾IDC现推出10台特价主流机型,配置为四核xeon3220/4G内存/500g企业级硬盘,限量10台,20Mbps独享带宽,1000元/月。售完即止。
如有需要,请联系我们!在此祝您财源广进!www.netshield.cn
淘宝店:http://netshield.taobao.com/ QQ:6520895