Laravel 如何在数据库中获取随机数据?(单条或多条)

Laravel >= 5.2:

User::inRandomOrder()->get();

获取指定数量的记录

// 5 表示要获取记录的数量
User::inRandomOrder()->limit(5)->get();
// 获取单条随机记录
User::inRandomOrder()->first();

或使用集合的 random 方法:

User::all()->random();
User::all()->random(10); // 想要获取记录的数量

Laravel 4.2.7 - 5.1:

User::orderByRaw("RAND()")->get();

Laravel 4.0 - 4.2.6:

User::orderBy(DB::raw('RAND()'))->get();

Laravel 3:

User::order_by(DB::raw('RAND()'))->get();
本文中的所有译文仅用于学习和交流目的,转载请务必注明文章译者、出处、和本文链接
我们的翻译工作遵照 CC 协议,如果我们的工作有侵犯到您的权益,请及时联系我们。

原文地址:https://stackoverflow.com/questions/1391...

译文地址:https://learnku.com/laravel/t/62134

本文为协同翻译文章,如您发现瑕疵请点击「改进」按钮提交优化建议
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 5
chenBJ

仅限mysql吗?

2年前 评论
MArtian 2年前

前几天刚好用到 ,也是百度来的.主要是效率很高几百万条的应该也合适 'SELECT t1.uid FROM tablename AS t1 JOIN (SELECT ROUND(RAND() * ((SELECT MAX(id) FROM tablename)-(SELECT MIN(id) FROM tablename))+(SELECT MIN(id) FROM tablename)) AS id) AS t2 WHERE t1.id >= t2.id ORDER BY t1.id LIMIT num'

2年前 评论

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