laravel如何从mysql数据库中随机抽取n条数据(高性能)
Song •
5410 次浏览 •
0个评论 •
2017年09月11日
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();
好的,这就是随机从数据库获取数据的4种方法,如果后续有更多方法,我会继续更新在本文中的!
-
laravel中distinct()的使用方法与去重 2017-09-11
-
Laravel将view缓存为静态html,laravel页面静态缓存 2021-10-09
-
[ laravel爬虫实战--基础篇 ] guzzle描述与安装 2017-11-01
-
[ 配置教程 ] 在ubuntu16.04中部署LNMP环境(php7+maridb且开启maridb远程以及nginx多域名访问 )并配置laravel环境 2017-07-18
-
mysql如何给运营人员添加只有查询权限的账号 2024-12-02
热门文章
-
mysql如何给运营人员添加只有查询权限的账号 2024-12-02
-
Mac 安装mysql并且配置密码 2024-11-20
-
阿里云不同账号(跨账号)ECS服务器同地域如何实现免费内网互通? 2024-11-12
-
electron安装使用better-sqlite3并解决NODE_MODULE_VERSION xxx. This version of Node.js requires 2024-11-06
-
Zerotier+Moon+Nginx实现内网穿透搭建网站 2024-08-23
更多相关好文