使用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中文網其他相關文章!