首頁 > 後端開發 > php教程 > 如何在 Laravel Eloquent 中使用 WHERE IN 子句實作子查詢?

如何在 Laravel Eloquent 中使用 WHERE IN 子句實作子查詢?

Barbara Streisand
發布: 2024-12-06 20:45:16
原創
735 人瀏覽過

How to Implement a Subquery with WHERE IN Clause in Laravel Eloquent?

Laravel 中使用 WHERE IN 的子查詢

在 Laravel 中,您可以使用子查詢執行複雜的查詢。一個常見的用例是帶有 WHERE IN 子句的子查詢。本文示範如何有效地實作這種查詢類型。

考慮以下SQL 查詢:

SELECT 
    `p`.`id`,
    `p`.`name`, 
    `p`.`img`, 
    `p`.`safe_name`, 
    `p`.`sku`, 
    `p`.`productstatusid` 
FROM `products` p 
WHERE `p`.`id` IN (
    SELECT 
        `product_id` 
    FROM `product_category`
    WHERE `category_id` IN ('223', '15')
)
AND `p`.`active`=1
登入後複製

使用Laravel 的Eloquent ORM,您可以透過以下程式碼實現此查詢:

Products::whereIn('id', function($query){
    $query->select('paper_type_id')
    ->from(with(new ProductCategory)->getTable())
    ->whereIn('category_id', ['223', '15'])
    ->where('active', 1);
})
->get();
登入後複製

在此範例中,我們首先在「產品」模型上建立查詢('產品::whereIn(...)')。 'whereIn' 子句指定我們要根據 'id' 欄位過濾 'Products',該欄位應包含在子查詢傳回的結果中。

子查詢本身是使用匿名函數定義的('$query => ...')。此子查詢從「product_category」表中選擇「paper_type_id」字段,假定該字段可透過與「ProductCategory」模型的關係來取得。使用 'with(...)->getTable()' 方法取得表名。

在子查詢中,我們新增條件來根據 'category_id' 欄位過濾結果,並確保'active' 欄位設定為 1。這些條件有助於縮小最終結果中包含的產品類別範圍。

透過使用此方法,您可以有效地檢索符合所需條件的產品無需執行昂貴的連接。

以上是如何在 Laravel Eloquent 中使用 WHERE IN 子句實作子查詢?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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