ChatGPT解决这个技术问题 Extra ChatGPT

如何在 Laravel 中执行此操作,子查询在哪里

如何在 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

我也可以通过加入来做到这一点,但我需要这种格式来提高性能。


g
giannis christofakis

考虑这段代码:

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

接受了这个答案,问题已经过时了,因为它与 Laravel 3 相关,并且进来的答案适用于 Laravel 4,下面的答案也适用于 4。
@lukaserat 有问题的查询正在应用 AND p.active=1 检查产品表,而您的查询将其应用于 ProductCategory 表......对吗?还是有什么我错过了..?
@hhsadiq 是的,它指的是 ProductCategory。
表名的好方法。这对我来说是一个加分项
适用于 laravel 5.5
C
Community

查看 Fluent 的 advanced where clause documentation。这是您要实现的目标的示例:

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 方法。
啊,Laravel3 ......是的,那会很困难。而且我认为在 Laravel3 中您使用 table() 方法而不是 from()。我在L3没有遇到过这种情况,对不起!
我看不到在 Illuminate\Database\Query\Builder 中采用 lambda 的 whereIn 方法是否已重命名为 whereSub?
R
Ramesh

您可以使用关键字“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();

P
Philipe

你可以在不同的查询中使用 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

这将生成您在问题中编写的相同查询。


D
Darkproduct

这是我从这里的多个答案中收集的 Laravel 8.x 方法:

使用查询生成器,不要直接编写 SQL。

使用模型并从那里确定一切。不要使用硬编码的表名或任何名称(列等)。

Product::select(['id', 'name', 'img', 'safe_name', 'sku', 'productstatusid'])
    ->whereIn('id', ProductCategory::select(['product_id'])
        ->whereIn('category_id', ['223', '15'])
    )
    ->where('active', 1)
    ->get();

M
Madan Sapkota

该脚本在 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` = ?

有没有办法使用 ProductCategory 的范围?
@SergeiKrivosheenko 是的,看看我对这个问题的回答。
A
Aditya Singh

以下代码对我有用:

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

            })
->get();

L
LC Yoong

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

p
panqingqiang
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();

a
a3rxander

使用变量

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

这将导致两个查询,而不仅仅是一个。您可以将第一个查询构建器插入第二个查询构建器,而无需获得第一个 quary 的结果。有关更多详细信息,请参阅飞利浦的回答。
l
liquid207

请试试这个在线工具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();