首页 > 数据库 > mysql教程 > 如何将 Laravel 的 `whereIn` 与子查询结合使用?

如何将 Laravel 的 `whereIn` 与子查询结合使用?

Susan Sarandon
发布: 2024-12-25 13:32:55
原创
524 人浏览过

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']) 将条件添加到子查询。
  • $query->where('active', 1) 向子查询添加另一个条件。
  • ->get() 检索结果。

以上是如何将 Laravel 的 `whereIn` 与子查询结合使用?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板