• 技术文章 >php框架 >Laravel

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

    藏色散人藏色散人2020-07-03 11:55:23转载1375

    下面由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条数据(高性能)的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:csdn,如有侵犯,请联系admin@php.cn删除
    专题推荐:laravel mysql
    上一篇:Blade模板是什么? 下一篇:了解Redis这个核心数据类型
    大前端线上培训班

    相关文章推荐

    • PHP Laravel定时任务Schedule【干货】• 看了本文安装laravel-queue-rabbitmq绝对没问题• Laravel中两种记录日志的方式• Laravel-S居然能提升这么高性能!

    全部评论我要评论

  • 锋锋啦

    这个性能最低吧,explain每次都扫全表了,不合适。

    2020-07-07

  • 红烧茄子

    这种代码 直接拉出去打500大板!!!数据量一上来 直接卡爆!!!

    2021-02-07

  • 取消发布评论发送
  • 1/1

    PHP中文网