如何使用 Eloquent 或 Fluent 檢索 Laravel 中的隨機行?

Patricia Arquette
發布: 2024-11-11 22:36:03
原創
297 人瀏覽過

How to Retrieve a Random Row in Laravel Using Eloquent or Fluent?

使用Eloquent 或Fluent 在Laravel 中進行隨機行檢索

從資料庫中擷取隨機行在各種場景中都是一個有用的操作。 Laravel 提供了兩種主要方法來實現這一目標:Eloquent 和 Fluent。本文探討如何利用這些方法在 Laravel 中有效率地檢索隨機行。

Eloquent

對於 Laravel 5.2 及更高版本, inRandomOrder() 方法提供了選擇隨機行的便捷方法。只需在所需模型上呼叫此方法:

$randomUser = User::inRandomOrder()->get();
登入後複製

這將傳回 User 模型的隨機實例。您也可以使用limit() 方法指定要擷取的隨機行數:

$randomUsers = User::inRandomOrder()->limit(5)->get();
登入後複製

Fluent

對於Laravel 5.2 之前的版本,Fluent 提供了使用orderByRaw () 另一種檢索隨機行的方法:

// Laravel 5.1 and below
$randomUser = User::orderByRaw(DB::raw('RAND()'))->get();
登入後複製

不進行計數操作的隨機記錄檢索

不執行計數操作檢索隨機行的目標源於性能考量。對於大型資料集,計算記錄數量的計算成本可能很高。透過利用 SQL 中的 RAND() 函數,我們可以有效率地取得隨機行,而不會產生計數開銷。

結論

本文中介紹的方法提供了使用 Eloquent 或 Fluent 在 Laravel 中檢索隨機行的有效方法。 Laravel 5.2 及更高版本中的 inRandomOrder() 方法是首選且最直接的方法。對於早期版本,Fluent 透過 orderByRaw() 方法提供了可行的替代方案。

以上是如何使用 Eloquent 或 Fluent 檢索 Laravel 中的隨機行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板