如何在 laravel 8 中编写子查询?

Posted

技术标签:

【中文标题】如何在 laravel 8 中编写子查询?【英文标题】:How to write sub queries in laravel 8? 【发布时间】:2022-01-03 15:54:10 【问题描述】:
SELECT 
    posts.id,
    (select count(*) from post_likes where post_id = 13 and user_id = 12) as post_like
FROM
    posts
LIMIT 5

如何在 Laravel 查询构建器中编写此查询?

【问题讨论】:

【参考方案1】:

如果您的 ORM 模型已定义(并且您同时拥有 PostPostLike 模型),请在您的 Post.php 模型中创建关系(如果尚未),例如:

public function likes()
  return $this->hasMany(PostLike::class);

然后,如果您只需要计数,请尝试以下操作:

$userId = 12;

$postList = Post::query()
    ->whereId(13)
    ->withCount(['likes', 'likes AS post_like' => function ($query) use($userId) 
        $query->where('user_id', '=', $userId);
    ])
    ->limit(5)
    ->get();
// Then do something with result.
foreach ($postList as $post) 
    $count = $post['post_like'];

注意上面我们使用post_like这个别名,并且限制为user_id,只是对OP的要求比较高;否则我们可以简单地将likes_count 设置为关系的数量,例如:

->withCount('likes')

但是您可以使用 whereHas(...) eloquent 方法对子查询使用关系,例如:

Post::query()->whereHas('likes', function($query)
  $query->where(...your statements for sub query go there);
, '>', 4)->limit(5)->get(); //Select where more than 4 relation found with given parameters

更多信息请见:https://laravel.com/docs/8.x/eloquent-relationships#querying-relationship-existence

【讨论】:

@InfasMohammed 我刚刚编辑过,答案来自乌鲁丁 ;-)

以上是关于如何在 laravel 8 中编写子查询?的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Laravel 8 中使用 PostgreSQL 中的子查询通过 group by 子句获取行值?

如何在 Laravel-5 中构建子查询 [重复]

如何在laravel中的子查询中求和

如何在 Laravel 的 fluent 中进行子查询?

如何做这个 laravel 子查询

如何在 laravel 5.4 中编写 mysql 查询?