ホームページ > データベース > mysql チュートリアル > Laravel の「whereIn」をサブクエリで使用するにはどうすればよいですか?

Laravel の「whereIn」をサブクエリで使用するにはどうすればよいですか?

Susan Sarandon
リリース: 2024-12-25 13:32:55
オリジナル
552 人が閲覧しました

How to Use Laravel's `whereIn` with a Subquery?

WHERE IN 句を使用した Laravel サブクエリ

Laravel の一般的なタスクは、WHERE IN 句内のサブクエリを使用してデータを取得することです。これを実現するには、クロージャを指定して whereIn() メソッドを利用します。

たとえば、次のクエリがあるとします。

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 に変換するには、次のようにします。次のコードを使用できます:

Products::whereIn('id', function($query){
    $query->select('paper_type_id')
    ->from(with(new ProductCategory)->getTable())
    ->whereIn('category_id', ['223', '15'])
    ->where('active', 1);
})
->get();
ログイン後にコピー

この中でcode:

  • Products::whereIn('id', ...) は、WHERE IN 句内のサブクエリを開始します。
  • クロージャー関数はサブクエリを定義します。
  • $query->select('paper_type_id') は、 subquery.
  • $query->from(with(new ProductCategory)->getTable()) は、サブクエリで使用されるテーブルを指定します。
  • $query->whereIn( 'category_id', ['223', '15']) に条件を追加します。 subquery.
  • $query->where('active', 1) はサブクエリに別の条件を追加します。
  • ->get() は結果を取得します。

以上がLaravel の「whereIn」をサブクエリで使用するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート