微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – Yii和ActiveRecord Group by Count

我对Yii比较陌生,想尝试一下.我在互联网上四处看看,我完全不知道如何处理这个问题.我已经掌握了Yii的基础知识,但我认为这是非常先进的,或者我只是愚蠢.

我有一个MysqL表,其中列出了所购买的商品.该表将CUSTOMER_ID作为主要字段,每个CUSTOMER_ID可能具有多个ITEM.我想通过TRANSACTION_ID进行计数,然后根据以下逻辑进行评估:

1) IF myCount = 1 then businessType = 'New'; 
2) If myCount = 2 then businessType = 'Repeat'; 
3) If myCount > 2 then businessType = '2+ Repeat'; 

我不知道在哪里以及如何做到这一点最好的方法呢? afterSave()?还是在控制器中?我必须将查询结果导入GROUPED CActiveDataProvider对象,因为我将此数据提供给Highcharts.

我的分组需要看如下(从最低级别到最高级别):

businessType->store->item->{Count(ITEM), SUM(Cost)}

遗憾的是,我无法在表中添加变量,并且非常希望无需实现此目的.任何帮助赞赏!

解决方法:

为此,您需要使用CDbCriteria将结果分组到CActiveDataProvider中.看到这里http://www.yiiframework.com/doc/api/1.1/CDbCriteria#group-detail.你需要在你的控制器中实现这样的东西;

$criteria = new CDbCriteria;
$criteria->select = 'the columns to select, and maybe SUM()';
$criteria->group = 'columns to group by';
etc
etc

$dataProvider = new CActiveDataProvider('model name', $criteria);

在不知道数据库的确切实现的情况下,我只能给出一个通用的例子,但你应该找到适合自己的东西.我不确定如何将您所说的分组称为businessType-> store-> item-> {Count(ITEM),SUM(Cost)},因为您尚未显示数据库模型结构.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐