如何从mysql数据库中随机获取任意条数据?

我在做一个随机出题的小应用,需要在mysql数据库的题库表里随机选出任意条数据作为
题目,每条数据为一道题目,从网上查了很多资料,基本上有两种,一种是使用 ORDER BY rand()语句,这个语句可以实现取任意条数据,但是官网提示数据量大时内存消耗会很大,查询会很慢,另一种是SELECT
table. *
FROM
(SELECT
ROUND(RAND() * (SELECT
MAX(id)
FROM
table)) random_num,
@num:=@num + 1
FROM
(SELECT @num:=0) AS a, table
LIMIT N) AS b,
table AS t
WHERE
b.random_num = t.id;
这种语句有一个问题,就是我想选出20条数据,有时候会返回19条,就是会出现返回数据不够的情况,请问各位大神有什么好办法没?最好返回的数据可以不按自增长id排序,题目顺序需要打乱。

3个回答

order by random 会把整个表数据顺序打乱,这样就可以直接取需要的条数了,数据量不是特别大的时候可以这样用

u010402129
坚持信仰的石头 目前好像就是只能用这个方法了
接近 2 年之前 回复

如果在where 子句中使用参数,会导致全表扫描。
因为SQL只有在运行时才会解析局部变量,但优化程序不能将访问计划的选择推 迟到运行时;
它必须在编译时进行选择。然而,如果在编译时建立访问计划,变量的值还是未知的,因而无法作为索引选择的输入项。

你的这个sql多重嵌套使用参数 你算算多少次全表扫描了。个人觉得这个需求完全可以由程序来做,只需要写简单的sql,动态生成sql。

u010402129
坚持信仰的石头 由程序做应该会很慢吧,提取出来数据还需要在写入数据库
接近 2 年之前 回复

SELECT * FROM table AS t1 JOIN (SELECT ROUND(RAND() * ((SELECT MAX(id) FROM table)-20)) AS id) AS t2
WHERE t1.id >= t2.id
ORDER BY t1.id LIMIT 20;

u010402129
坚持信仰的石头 这样只能选出连续的数据,我是想选出不连续,并且最好可以打乱前后顺序的方法
接近 2 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐