分情况统计 怎么写查询呀

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

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
讨论数量: 21

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

1年前 评论

可以使用 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,
    ")
// ...
1年前 评论
whr_er 1年前
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
1年前 评论
勇敢的心 (作者) 1年前
tiantian10000 (楼主) 1年前
勇敢的心 (作者) 1年前
tiantian10000 (楼主) 1年前
tiantian10000 (楼主) 1年前
勇敢的心 (作者) 1年前
tiantian10000 (楼主) 1年前
tiantian10000 (楼主) 1年前
ShiKi
select count(*),status from users group by status
1年前 评论
tiantian10000 (楼主) 1年前

file

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

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

1年前 评论
jack_f 1年前

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

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

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