分段截取替代 mysql rand()

需要随机从数据拿去几条数据

select * from  `tb` ORDER BY rand () limit  10

非常耗时

所以采用分段获取

$count =  DB::table('tb')->count();
$limit = 10;
$offset = rand(0, $count - $limit);
if ($offset > $count-$limit) {
   $offset = 0;
}
$data=DB::table('tb')->limit($limit)->offset($offset)->get();

但是 这样拿取的数据id是分段的 ,是有规律的。
所以数据库表新增一个随机数据字段rand_value,新增的时候给他一个随机数据
查询改成

$data=DB::table('tb')->limit($limit)->orderBy('rand_value')->offset($offset)->get();

这样就好了

本作品采用《CC 协议》,转载必须注明作者和本文链接
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!