laravel从mysql数据库中随机抽取n条数据(高性能)

laravel从mysql数据库中随机抽取n条数据(高性能),第1张

概述laravel从mysql数据库中随机抽取n条数据(高性能)

下面由Laravel教程栏目给大家介绍laravel从MysqL数据库中随机抽取n条数据的方法,希望对需要的朋友有所帮助!

laravel如何高性能地从MysqL数据库中随机获取n条数据,有时候我们常常会需要从数据库随机获取数据,比如:给工作人员随机分配10个订单,随机从数据库中随机抽查100个用户;这样我们就需要随机从数据库获取数据。

一、使用原生sql从数据库获取100条数据

MysqL官网可以看到,可以让ORDER BY RAND()liMIT一起使用,可以用于从多行结果中选取随机的一部分。

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

那么在laravel中使用原生sql也很简单,如下所示:

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

二、使用原始表达式从数据随机获取数据

我们都知道laravel的原始表达式,我们可以使用DB::raw('RAND()')从数据库随机获取数据。同时你还可以使用orderByRaw('RAND()')从数据库随机获取数据,和DB::raw('RAND()')效果一样

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

三、使用laravel的inRandomOrder方法随机获取数据

laravel中使inRandomOrder会对数据结果进行随机排序,达到我们随机从数据库获取数据的效果:

$info = DB::table('users')            ->inRandomOrder()            ->take(5)            ->get();
总结

以上是内存溢出为你收集整理的laravel从mysql数据库中随机抽取n条数据(高性能)全部内容,希望文章能够帮你解决laravel从mysql数据库中随机抽取n条数据(高性能)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/langs/1227919.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存