লারাভেলে কীভাবে এটি করা যায়, সাবকোয়ারি যেখানে রয়েছে


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 সংক্রান্ত যে প্রশ্নটি ছিল তা পুরানো in
মার্ক বুর্কে

3
@ লুকাশাসেরাত প্রশ্নে থাকা ক্যোয়ারী এ্যান্ড প্রয়োগ করছে pactive= 1 টি পণ্যের টেবিলে পরীক্ষা করুন যেখানে আপনার ক্যোয়ারী এটি প্রোডাক্ট ক্যাটাগরির টেবিলে প্রয়োগ করছে .... ঠিক ?? নাকি আমি এখানে কিছু মিস করছি ..?
hhsadiq

@hhsadiq হ্যাঁ, এটি পণ্যশ্রেণীতে উল্লেখ করা হচ্ছে to
lukaserat

1
টেবিলের নামটির সাথে দুর্দান্ত পন্থা। এটি আমার জন্য একটি প্লাস
অলউইন কেসলার


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 পদ্ধতিটি থেকে সমর্থন করে।
মার্ক বুর্কে

আহ, লারাভেল ৩ ... হ্যাঁ, তখন খুব কঠিন হতে চলেছে। এবং আমি লারাভেল 3-তে মনে করি আপনি এর table()পরিবর্তে পদ্ধতিটি ব্যবহার করেন from()। এল 3 এ আমার এমন অবস্থা হয়নি, দুঃখিত!
দ্রুহোহ

আমি কোনও পদ্ধতি দেখতে পাচ্ছি না যা আলোকিত \ ডাটাবেস \ কোয়েরি \ বিল্ডারে ল্যাম্বদা লাগে এমন কোনও পদ্ধতিতে এর নামকরণ করা হয়েছে কোথায়?
nbransby

20

আপনি কীওয়ার্ড "ব্যবহার ($ বিভাগ_আইডি)" ব্যবহার করে ভেরিয়েবল ব্যবহার করতে পারেন

$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

স্ক্রিপ্টটি লারাভেল 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();

এসকিউএল উত্পন্ন করে

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

ল্যারাভেল ৪.২ এবং তার বাইরে, সম্পর্কের অনুসন্ধানের চেষ্টা করতে পারে: -

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

দয়া করে এই অনলাইন সরঞ্জামটি স্কয়ার 2 বিল্ডার ব্যবহার করে দেখুন

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.