为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

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

2 回答

?
米琪卡哇伊

TA贡献1998条经验 获得超6个赞

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

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


查看完整回答
反对 回复 2018-11-03
  • 2 回答
  • 0 关注
  • 1535 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信