Rumah >pembangunan bahagian belakang >tutorial php >Bagaimana untuk Memilih Baris Rawak dalam Laravel: Kaedah Fasih, Fasih dan Koleksi?

Bagaimana untuk Memilih Baris Rawak dalam Laravel: Kaedah Fasih, Fasih dan Koleksi?

Susan Sarandon
Susan Sarandonasal
2024-11-12 15:56:02161semak imbas

How to Select Random Rows in Laravel: Eloquent, Fluent, and Collections Methods?

Memilih Baris Rawak dalam Laravel: Pendekatan Fasih dan Fasih

Dalam Laravel, terdapat berbilang kaedah untuk mendapatkan semula baris rawak daripada jadual pangkalan data . Menggunakan Eloquent atau Fluent, pembangun boleh mengakses kefungsian ini untuk pelbagai senario.

Antara Muka Fasih

Bermula dengan Laravel 5.2, antara muka Eloquent menyediakan kaedah inRandomOrder() khusus. Kaedah ini merombak hasil pertanyaan, dengan berkesan memilih baris rawak:

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

Untuk menentukan bilangan rekod rawak tertentu, gunakan kaedah had():

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

Antara Muka Fasih

Untuk versi Laravel yang lebih lama (sebelum 5.2), anda boleh menggunakan antara muka Fasih untuk mencapai kesan yang serupa:

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

Kaedah Pengumpulan

Sebagai alternatif, untuk Laravel 5.1 dan ke atas, anda boleh menggunakan kaedah rawak() pada koleksi yang dijana oleh pertanyaan Eloquent. Pendekatan ini mengembalikan satu rekod rawak atau nombor tertentu daripadanya:

User::all()->random();
User::all()->random(10);

Ingat untuk merujuk dokumentasi Laravel rasmi untuk keserasian versi tertentu dan variasi sintaks.

Atas ialah kandungan terperinci Bagaimana untuk Memilih Baris Rawak dalam Laravel: Kaedah Fasih, Fasih dan Koleksi?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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