mysql 随机行_mysql 如何选择随机行

最简单的方式是使用

mysql 的 ORDER BY RAND() 子句。

SELECT

col1  FROM  tbl  ORDER  BY  RAND()  LIMIT

10; 它能很好的运行在小表中。然而,对于大表,生成随机列表行时将产生一个严重的性能问题,MYSQL

需要对每一行进行随机,然后对它们排序。 即使你只想从10W的结果集中取其中随机10行,MySQL也需要对这10W行进行排序并且只提取其中的10行。   为了解决这个问题,我在

WHERE 子句中使用 RAND 并且不使用ORDER BY 子句。首先,你需要计算表中的总行数和你想要的得到随机行数。其次,在 WHERE

子句中加入该碎片数字,并要求结果只能小于(或等于)从这个碎片数字。

例如,假设你有一个20万行的表,你只需要从表中随机100行。这个碎片数是从100/总行数得到:100

/ 20万= 0.0005。

该查询将如下所示:SELECT

col1  FROM  tbl  WHERE  RAND() <= 0.0005;

为了得到准确的100行结果集,我们可以增加碎片数字和

limit限制:例如

SELECT

col1   FROM   tbl   WHERE

RAND()<=0.0006  limit  100;

原文:http://www.cnblogs.com/rongfengliang/p/3706183.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值