分情况统计 怎么写查询呀

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

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 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年前

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