分情况统计 怎么写查询呀

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

《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 21

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

4年前 评论
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
4年前 评论
勇敢的心 (作者) 4年前
tiantian10000 (楼主) 4年前
勇敢的心 (作者) 4年前
tiantian10000 (楼主) 4年前
tiantian10000 (楼主) 4年前
勇敢的心 (作者) 4年前
tiantian10000 (楼主) 4年前
tiantian10000 (楼主) 4年前
ShiKi
select count(*),status from users group by status
4年前 评论
tiantian10000 (楼主) 4年前

可以使用 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,
    ")
// ...
4年前 评论
whr_er 4年前

@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的数量呀 帮帮忙看看 谢谢哈

4年前 评论
jack_f 4年前

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

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

file

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

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