it-swarm.com.de

Wie kann man das in Laravel tun, wo in

Wie kann ich diese Abfrage in Laravel stellen:

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

Ich könnte das auch mit einem Join machen, aber ich brauche dieses Format für die Performance.

88
Marc Buurke

Betrachten Sie diesen Code:

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

Sehen Sie sich die erweiterte Dokumentation für Fluent an: http://laravel.com/docs/queries#advanced-wheres

Hier ist ein Beispiel, was Sie erreichen wollen:

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

Dies wird produzieren:

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

Sie können die Variable mithilfe des Schlüsselworts "use ($ category_id)" verwenden.

$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();
18
Ramesh

Der folgende Code hat für mich funktioniert:

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

            })
->get();
2
Aditya Singh
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
潘庆强

In Laravel 4.2 und höher können Sie versuchen, die Beziehung abzufragen: -

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

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

mit einer Variablen

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

Sie können Eloquent in verschiedenen Abfragen verwenden, um die Dinge leichter verständlich zu machen und zu verwalten:

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

und dann setzen wir alles zusammen:

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

Dadurch wird dieselbe Abfrage generiert, die Sie in Ihre Frage geschrieben haben.

0
Philipe