如何将 SQL "IN" 循环查询从 1 简化为同一查询中的多个 IN 检查?

How to simplify a SQL "IN" loop query from 1 to multiple IN checks in the same query?

我正在尝试简化这部分代码,我将循环数据库查询调用为单个数据库查询,然后我 运行 对结果进行循环。

我现在的问题是,如何才能不仅获得 app_categories table 中存在一行的一个类别的应用程序计数,而且每个类别的结果一次计数?

当前代码:

    foreach(DB::Table('categories')->get() as $category)
    {
        $appcount[$category->name] = DB::Table('apps')->where('active', 1)
            ->whereRaw('apps.id in (select app_id from app_categories where category_id = ?)', [$category->id])
            ->count();
    }

这将满足您的需求:

DB::table('categories')
    ->select('categories.id as category_id','categories.name as name',DB::raw('count(*) as apps_count'))
    ->leftJoin('app_categories','categories.id','=','apps_categories.category_id')
    ->leftJoin('apps','apps.id','=','apps_categories.app_id')
    ->where('apps.active',1)
    ->groupBy('categories.id')

另一种选择可能是使用 eloquent relation