zoukankan      html  css  js  c++  java
  • laravel如何从mysql数据库中随机抽取n条数据

    laravel如何从mysql数据库中随机抽取n条数据

    一、总结

    一句话总结:

    inRandomOrder():$userQuestions=UserQuestion::where($map)->inRandomOrder()->take($neededQuestionNum)->get();

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

    转自或参考:laravel如何从mysql数据库中随机抽取n条数据(高性能)
    https://blog.csdn.net/weixin_41981080/article/details/84452929

     

    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();
     
  • 相关阅读:
    Memcached 测试
    Task WaitAll的用法
    Linux Memcached 安装
    开发常用的一些插件
    转:浅析VO、DTO、DO、PO的概念、区别和用处
    转:数据库的快照隔离级别(Snapshot Isolation)
    转:nolock的替代方案-提交读快照隔离[行版本控制]
    转:介绍一个好用的抓取dump的工具-ProcDump
    把sqlserver查询结果复制到Excel出现数据记录遗漏
    ASP.NET_SessionId 不相同导致验证码出错
  • 原文地址:https://www.cnblogs.com/Renyi-Fan/p/11671298.html
Copyright © 2011-2022 走看看