mysql实现不使用limit查询第x条到第y条的数据
废话不多说直接上代码
SET @rownum = 0;
SELECT
*
FROM
emp a
INNER JOIN ( SELECT ( @rownum := @rownum + 1 ) ids, emp_id AS id
FROM emp ) AS b
ON a.emp_id = b.id
HAVING
ids BETWEEN 10 AND 20
实际上就是自定义一个自增的变量作为一个字段,通过子查询查出两个字段,一个是自增的变量,一个是原表的主键,通过连接查询以主键为查询条件。就能得出原表的所有数据和一个从1开始有序的列。这样就可以通过having来查询筛选需要的数据。不能用where ,where会报错。
可能就有人会问了,为什么使用limit就能简单实现的功能还需要这么多此一举??
其实是因为有一次面试,面试官问了我这个问题。当时问的我一脸懵逼啊!!
当时场面就一度很尴尬-- 我面试完就百度。。结果发现百度不到!!!!然后我又问了一些前辈,前辈给出了一个思路。于是就花了点时间将这个功能实现了出来。
如果有什么更好的方法,欢迎大家在下面留言~
本文介绍了一种在MySQL中不使用LIMIT实现特定范围数据查询的方法,通过自定义一个自增变量并结合子查询和连接查询,实现了从任意起始位置获取指定数量记录的功能。
701

被折叠的 条评论
为什么被折叠?



