Laravel에서 이것을 수행하는 방법, 하위 쿼리


120

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

조인으로도이 작업을 수행 할 수 있지만 성능을 위해이 형식이 필요합니다.

답변:


199

이 코드를 고려하십시오.

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에도 적용됩니다.
Marc Buurke 2014

3
@lukaserat 문제의 쿼리는 AND를 적용하고 p있습니다. active= 1 제품 테이블을 확인하고 쿼리는 ProductCategory 테이블에 적용합니다 .... right ?? 아니면 내가 놓친 게 있나 ..?
hhsadiq

@hhsadiq 예, ProductCategory를 참조하고 있습니다.
lukaserat

1
테이블 이름에 대한 좋은 접근 방식입니다. 그것은 나에게 플러스입니다
Alwin Kesler 2016

laravel 5.5에 대한 작업 고급
올렉 Shakhov

53

Fluent에 대한 고급 wheres 문서를 살펴보십시오 : 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
)

거의 다가 왔고 나는 지금 당분간 비슷한 쿼리로 혼란스러워했습니다. 그러나 where_in (laravel 3)에는 2 개의 인수가 필요하며 두 번째 인수는 배열입니다. 이 문제를 해결하는 방법을 아십니까? 또한 laravel 3이 from 메서드를 지원한다고 생각하지 않습니다.
Marc Buurke 2013 년

아, 라 라벨 3 ... 그래, 그거 힘들어. 그리고 Laravel3 table()에서는 from(). L3에서는 그런 상황이 없었습니다. 죄송합니다!
drewjoh

Illuminate \ Database \ Query \ Builder에서 람다를받는 whereIn 메서드를 볼 수 없습니다. whereSub로 이름이 바뀌 었습니까?
nbransby

20

"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();

5

다음 코드가 저에게 효과적이었습니다.

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

            })
->get();

3

Eloquent를 다양한 쿼리에서 사용할 수 있으며 이해하고 관리하기 쉽게 만들 수 있습니다.

$productCategory = ProductCategory::whereIn('category_id', ['223', '15'])
                   ->select('product_id'); //don't need ->get() or ->first()

그리고 우리는 모두 합쳤습니다.

Products::whereIn('id', $productCategory)
          ->where('active', 1)
          ->select('id', 'name', 'img', 'safe_name', 'sku', 'productstatusid')
          ->get();//runs all queries at once

이렇게하면 질문에 작성한 것과 동일한 쿼리가 생성됩니다.


2

스크립트는 Laravel 5.x 및 6.x에서 테스트되었습니다. static폐쇄 어떤 경우에는 성능을 향상시킬 수 있습니다.

Product::select(['id', 'name', 'img', 'safe_name', 'sku', 'productstatusid'])
            ->whereIn('id', static function ($query) {
                $query->select(['product_id'])
                    ->from((new ProductCategory)->getTable())
                    ->whereIn('category_id', [15, 223]);
            })
            ->where('active', 1)
            ->get();

SQL 생성

SELECT `id`, `name`, `img`, `safe_name`, `sku`, `productstatusid` FROM `products` 
WHERE `id` IN (SELECT `product_id` FROM `product_category` WHERE 
`category_id` IN (?, ?)) AND `active` = ?

1

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');
}

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

변수 사용

$array_IN=Dev_Table::where('id',1)->select('tabl2_id')->get();
$sel_table2=Dev_Table2::WhereIn('id',$array_IN)->get();

-2

이 온라인 도구 sql2builder를 사용해보십시오

DB::table('products')
    ->whereIn('products.id',function($query) {
                            DB::table('product_category')
                            ->whereIn('category_id',['223','15'])
                            ->select('product_id');
                        })
    ->where('products.active',1)
    ->select('products.id','products.name','products.img','products.safe_name','products.sku','products.productstatusid')
    ->get();
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.