laravel高性能从mysql数据库中随机获取n条数据

2022-02-1421:07:19后端程序开发Comments1,439 views字数 744阅读模式

laravel如何高性能地从mysql数据库中随机获取n条数据,有时候我们常常会需要从数据库随机获取数据,比如:给工作人员随机分配10个订单,随机从数据库中随机抽查100个用户;这样我们就需要随机从数据库获取数据。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/23187.html

一、使用原生SQL从数据库获取100条数据文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/23187.html

Mysql官网可以看到,可以让ORDER BY RAND()LIMIT一起使用,可以用于从多行结果中选取随机的一部分。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/23187.html

SELECT * FROM table WHERE name="" ORDER BY RAND() LIMIT 100;

那么在laravel中使用原生SQL也很简单,如下所示:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/23187.html

$info = DB::select('SELECT * FROM table WHERE name="" ORDER BY RAND() LIMIT 100');

二、使用原始表达式从数据随机获取数据文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/23187.html

我们都知道laravel的原始表达式,我们可以使用DB::raw('RAND()')从数据库随机获取数据。同时你还可以使用orderByRaw('RAND()')从数据库随机获取数据,和DB::raw('RAND()')效果一样文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/23187.html

$info=self::where('dealing','<>','')        ->orderBy(DB::raw('RAND()'))        ->take(5)        ->get();

三、使用laravel的inRandomOrder方法随机获取数据文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/23187.html

laravel中使inRandomOrder会对数据结果进行随机排序,达到我们随机从数据库获取数据的效果:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/23187.html

$info = DB::table('users')            ->inRandomOrder()            ->take(5)            ->get();
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/23187.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/bc/23187.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定