如何在Laravel中执行此操作,子查询在

2022-08-30 06:37:34

如何在Laravel中进行此查询:

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

我也可以通过联接来执行此操作,但我需要这种格式来提高性能。


答案 1

请考虑以下代码:

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

答案 2

查看 Fluent 的高级 where 子句文档。以下是您要尝试实现的目标的示例:

DB::table('users')
    ->whereIn('id', function($query)
    {
        $query->select(DB::raw(1))
              ->from('orders')
              ->whereRaw('orders.user_id = users.id');
    })
    ->get();

这将产生:

select * from users where id in (
    select 1 from orders where orders.user_id = users.id
)

推荐