分情况统计 怎么写查询呀

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

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
讨论数量: 22

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周前
zhaojjiang 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周前

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