分情况统计 怎么写查询呀

比如我需要统计users表 status 等于 0 1 2 这几种情况 分别的数量

《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 21

DB::table('***') ->selectRaw("status,count('id') as count") ->groupBy('status') ->pluck('count', 'status')->toArray();

3年前 评论
select count(if(status=0,1,null)) status_0_num,count(if(status=1,1,null)) status_1_num,count(if(status=2,1,null)) status_2_num from users
3年前 评论
勇敢的心 (作者) 3年前
tiantian10000 (楼主) 3年前
勇敢的心 (作者) 3年前
tiantian10000 (楼主) 3年前
tiantian10000 (楼主) 3年前
勇敢的心 (作者) 3年前
tiantian10000 (楼主) 3年前
tiantian10000 (楼主) 3年前
ShiKi
select count(*),status from users group by status
3年前 评论
tiantian10000 (楼主) 3年前

可以使用 mysql 的 case then

User::query()
    ->selectRaw("
        sum(case when status = 1 then 1 end) as status_1_total,
        sum(case when status = 2 then 1 end) as status_2_total,
    ")
// ...
3年前 评论
whr_er 3年前

@jack_f

 $query = $Plan::query() ->where('user_id', '=', $user_id) ->orderByDesc('id') ->select('id', 'type', 'user_id', 'categories_id', 'status') ->limit(10) ->get();

我这个查询有条件 和最后的limit 的限制 我怎么再这个查询的结果 统计 不同status的数量呀 帮帮忙看看 谢谢哈

3年前 评论
jack_f 3年前

你先查询10条出来,然后把查询放到子查询里面 from 条件,具体这里使用: $this->query = DB::table(DB::raw("({$this->query->toSql()}) as cashier_order")) ->selectRaw(' xxxxx ->mergeBindings($this->query);

3年前 评论
tiantian10000 (楼主) 3年前

file

3年前 评论
tiantian10000 (楼主) 3年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!