[英]Yii and 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)}
,因为你没有显示你的数据库和模型结构。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.