Rumah > rangka kerja php > Laravel > laravel从mysql数据库中随机抽取n条数据(高性能)

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

藏色散人
Lepaskan: 2020-07-03 11:55:23
ke hadapan
3965 orang telah melayarinya

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

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;
Salin selepas log masuk

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

$info = DB::select('SELECT * FROM table WHERE name="" ORDER BY RAND() LIMIT 100');
Salin selepas log masuk

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

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

$info=self::where(&#39;dealing&#39;,&#39;<>&#39;,&#39;&#39;)
        ->orderBy(DB::raw(&#39;RAND()&#39;))
        ->take(5)
        ->get();
Salin selepas log masuk

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

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

$info = DB::table(&#39;users&#39;)
            ->inRandomOrder()
            ->take(5)
            ->get();
Salin selepas log masuk

 

Atas ialah kandungan terperinci laravel从mysql数据库中随机抽取n条数据(高性能). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:csdn.net
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan