Как это сделать в Laravel, подзапрос, где в

72

Как я могу сделать этот запрос в 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

Я мог бы также сделать это с помощью соединения, но мне нужен этот формат для производительности.

Теги:
subquery
where-in
laravel-3

6 ответов

111
Лучший ответ

Рассмотрим этот код:

Products::whereIn('id', function($query){
    $query->select('paper_type_id')
    ->from(with(new ProductCategory)->getTable())
    ->whereIn('category_id', ['223', '15'])
    ->where('active', 1);
})->get();
  • 1
    Принял этот ответ, так как вопрос устарел, поскольку он касался Laravel 3, и ответы, которые приходят, относятся к Laravel 4, ответ ниже будет работать и для 4.
  • 3
    @lukaserat рассматриваемый запрос применяет AND p . active = 1 проверить таблицы продуктов, тогда как ваш запрос применяет его к таблице ProductCategory .... правильно ?? или мне чего-то не хватает ..?
Показать ещё 2 комментария
35

Взгляните на документацию Advanced wheres для Fluent: http://laravel.com/docs/queries#advanced-wheres

Вот пример того, чего вы пытаетесь достичь:

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
)
  • 0
    Это близко, и я уже некоторое время ломаю голову над подобными вопросами. Но where_in (laravel 3) требует 2 аргумента, второй из которых является массивом. Есть идеи, как сделать это правильно? Кроме того, я не думаю, что Laravel 3 поддерживает метод from.
  • 0
    Ах, Laravel3 ... Да, тогда это будет сложно. И я думаю, что в Laravel3 вы используете метод table() вместо from() . У меня не было такой ситуации в L3, извините!
Показать ещё 1 комментарий
13

Вы можете использовать переменную, используя ключевое слово "use ($ category_id)"

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

Для меня работал следующий код:

$result=DB::table('tablename')
->whereIn('columnName',function ($query) {
                $query->select('columnName2')->from('tableName2')
                ->Where('columnCondition','=','valueRequired');

            })
->get();
0
Product::from('products as p')
->join('product_category as pc','p.id','=','pc.product_id')
->select('p.*')
->where('p.active',1)
->whereIn('pc.category_id', ['223', '15'])
->get();
0

Laravel 4.2 и выше, может использовать запрос отношения try: -

Products::whereHas('product_category', function($query) {
$query->whereIn('category_id', ['223', '15']);
});

public function product_category() {
return $this->hasMany('product_category', 'product_id');
}

Ещё вопросы

Сообщество Overcoder
Наверх
Меню