MySQL中如何优雅的随机取出数据

MySQL中如何优雅的随机取出数据


  很多时候可能会涉及到随机从数据表中取出几条记录,例如单词APP锁屏显示单词这种,这个功能的实现方法有很多

方法一

  通过MySQL的order by rand()来实现。
  如:select word from words order by rand() limit 3;使用explain对语句进行解析,可以看到Using temporary,需要使用临时表;Using filesort,需要使用排序。之前提到,对于InnoDB表来说,执行全字段排序会减少磁盘访问,因此会被优先选择。而对于内存表,回表过程只是简单地根据数据行的位置,直接访问内存得到数据,根本不会导致多访问磁盘。优化器没有了这一层顾虑,那么它会优先考虑的,就是用于排序的行越少越好了,所以,MySQL这时就会选择rowid排序。所以这个情况下用的是rowid排序。
  这条语句的执行流程是这样的:
  1. 创建一个临时表。这个临时表使用的是memory引擎,表里有两个字段,第一个字段是double类型,为了后面描述方便,记为字段R,第二个字段是varchar(64)类型,记为字段W。并且,这个表没有建索引。
  2. 从words表中,按主键顺序取出所有的word值。对于每一个word值,调用rand()函数生成一个大于0小于1的随机小数,并把这个随机小数和word分别存入临时表的R和W字段中,到此,扫描行数是10000(假设word表一共10000行)。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值