xiaobuou2017 2017-05-12 02:45 采纳率: 0%
浏览 1988
已结题

sql server 在thinkphp中将查询结果分组显示并统计相同结果的数量

有三张表
1. 图片说明

将查询结果以商品分组,将每样商品的评价个数统计出来并计算商品分数,样式如下
1. 图片说明

自己在thinkphp里面写的代码如下,group里面的字段老是报错,统计结果也不对

 $model = M('rkdb');
$field = array('a.time,a.pid,a.evaluate,b.name,c.name,c.gg');
$list = $model
            ->alias('a')
            ->join('__GYSB__ as b on b.no=a.gid','LEFT')
            ->join('__SPB__ as c on a.pid=c.no')
            ->group('a.pid')
            ->field($field)
            ->select();
                        foreach($list as $value){
            //获取所有评价的次数
            //好
            $onecount = M('rkdb')->where(array('no'=>$value['no'],'pingjia'=>'好'))->count();
            $value['onelevel'] =!$onecount?0:$onecount;
            //较好
            $twocount =  M('rkdb')->where(array('no'=>$value['no'],'pingjia'=>'较好'))->count();
            $value['twolevel'] = !$twocount?0:$twocount;
            //一般
            $threecount =  M('rkdb')->where(array('no'=>$value['no'],'pingjia'=>'一般'))->count();
            $value['threelevel'] = !$threecount?0:$threecount;
            //差
            $fourcount =  M('rkdb')->where(array('no'=>$value['no'],'pingjia'=>'差'))->count();
            $value['forulevel'] = $fourcount;
            //获取总分
            $value['totalcount'] = ($onecount*5)+($twocount*4)+($threecount*3)+($fourcount*4);
            $array[]=$value;

如上,该怎么对查询数据进行分组并统计 评价个数以及 总分呢

  • 写回答

0条回答

    报告相同问题?

    悬赏问题

    • ¥17 pro*C预编译“闪回查询”报错SCN不能识别
    • ¥15 微信会员卡接入微信支付商户号收款
    • ¥15 如何获取烟草零售终端数据
    • ¥15 数学建模招标中位数问题
    • ¥15 phython路径名过长报错 不知道什么问题
    • ¥15 深度学习中模型转换该怎么实现
    • ¥15 HLs设计手写数字识别程序编译通不过
    • ¥15 Stata外部命令安装问题求帮助!
    • ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
    • ¥15 TYPCE母转母,插入认方向