【转】mysql top n的查询

纠结了很久,但是就是搞不明白 为什么mysql不支持top语法。
我们知道,在ms sql server中或access中,
若要查询前10条记录,使用top 10 *即可,
但在mysql中不支持这个写法,它用limit 10。
 
我们可以利用MySQL中SELECT支持的一个子句——LIMIT——来完成这项功能。
LIMIT可以实现top N查询,也可以实现M至N(某一段)的记录查询,具体语法如下:
SELECT * FROM MYTABLE
ORDER BY AFIELD
LIMIT offset, recnum
其中offset为从第几条(M+1)记录开始,recnum为返回的记录条数。例:
select * from mytable
order by afield
limit 2, 5
即意为从第3条记录开始的5条记录。
posted @ 2012-12-24 23:57  阿夏  阅读(149)  评论(0编辑  收藏  举报