首页 >数据库 >mysql教程 >如何在 Laravel 中使用'WHERE IN”中的子查询高效检索产品数据?

如何在 Laravel 中使用'WHERE IN”中的子查询高效检索产品数据?

Barbara Streisand
Barbara Streisand原创
2024-12-09 13:49:11816浏览

How to Efficiently Retrieve Product Data in Laravel Using a Subquery in `WHERE IN`?

Laravel 子查询 WHERE IN:

您正在寻找一种使用子查询从 Laravel 中的产品表中检索产品数据的高性能方法指定要包含的product_id 值。虽然存在连接替代方案,但出于优化目的,您更喜欢基于子查询的方法。

解决方案:

下面是满足您的要求的代码,利用其中子句:

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

解释:

  • 查询以 Products 模型库开始,它表示我们要从中检索数据的目标表。
  • 使用whereIn子句,指定
    products表的id列作为要查询的列评估。
  • 使用嵌套闭包来定义子查询。在此闭包中,我们从使用 with(new ProductCategory)->getTable() 创建的临时表中选择 paper_type_id。
  • 然后子查询应用必要的过滤器,包括 whereIn('category_id', ['223 ', '15']) 将结果限制为特定类别,where('active', 1) 仅包含活动products。
  • 最后使用get()执行整个查询,高效检索所需的产品数据。

以上是如何在 Laravel 中使用'WHERE IN”中的子查询高效检索产品数据?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn