Laravel में यह कैसे करें, उपकुंजी जहां में है


120

मैं लारवेल में यह प्रश्न कैसे कर सकता हूं:

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
इस उत्तर को स्वीकार कर लिया गया है, प्रश्न आउट ऑफ डेट है क्योंकि यह लारवेल 3 से संबंधित था, और आने वाले उत्तर लारावेल 4 के लिए हैं, नीचे दिए गए उत्तर 4 अस्वेल के लिए काम करेंगे।
मार्क बुर्के

3
प्रश्न में क्वेरी को @lukaserat लागू कर रहा है pactive= 1 उत्पादों की तालिकाओं पर जांच करें जबकि आपकी क्वेरी इसे ProductCategory की तालिका में लागू कर रही है .... सही ?? या मुझे कुछ याद आ रहा है ..?
हसदियाक

@hhsadiq हाँ, यह ProductCategory की बात कर रहा है।
लुकासरैट

1
तालिका नाम के साथ अच्छा दृष्टिकोण। यह मेरे लिए एक प्लस है
एल्विन केसलर

लार्वा 5.5 के लिए ठीक काम
ओलेग शाखोव

53

धाराप्रवाह के लिए उन्नत व्हेरेस प्रलेखन पर एक नज़र डालें: 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
)

वह करीब आता है, और मैं पिछले कुछ समय से इसी तरह के सवालों से घबरा रहा हूं। लेकिन जहाँ_लीन (लार्वा 3) में 2 तर्कों की आवश्यकता होती है, दूसरे में एक सरणी होती है। किसी भी विचार कैसे यह अधिकार पाने के लिए? इसके अलावा, मुझे नहीं लगता कि लार्वा 3 विधि से समर्थन करता है।
मार्क बर्क

आह, Laravel3 ... हाँ, यह मुश्किल होने जा रहा है। और मुझे लगता है कि Laravel3 में आप table()इसके बजाय विधि का उपयोग करते हैं from()। मुझे L3 में वह स्थिति नहीं मिली, क्षमा करें!
ड्रूजोह

मैं यह नहीं देख सकता कि इलुमिनटेट \ डेटाबेस \ क्वेरीरी बिल्डर में एक लैम्बडा लेने वाली विधि का नाम कहां रखा गया है?
nbransby

20

आप कीवर्ड "उपयोग ($ 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

आप विभिन्न प्रश्नों में एलोक्वेंट का उपयोग कर सकते हैं और चीजों को समझना और समझना आसान बना सकते हैं:

$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

लारवेल 4.2 और उसके बाद, कोशिश कर सकते हैं संबंध क्वेरी का उपयोग करें: -

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();
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.