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
조인으로도이 작업을 수행 할 수 있지만 성능을 위해이 형식이 필요합니다.
답변
이 코드를 고려하십시오.
Products::whereIn('id', function($query){
$query->select('paper_type_id')
->from(with(new ProductCategory)->getTable())
->whereIn('category_id', ['223', '15'])
->where('active', 1);
})->get();
답변
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
)
답변
“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();
답변
다음 코드가 저에게 효과적이었습니다.
$result=DB::table('tablename')
->whereIn('columnName',function ($query) {
$query->select('columnName2')->from('tableName2')
->Where('columnCondition','=','valueRequired');
})
->get();
답변
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
이렇게하면 질문에 작성한 것과 동일한 쿼리가 생성됩니다.
답변
스크립트는 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` = ?
답변
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');
}