在Yii1(或Yii2)中,AR类的find方法返回未被定义的字段,如何才能让这个字段在结果集中显示出来?

问题详情

是这样的,比如我定义了一个AR类,叫ArticleBrowseTime,定义了一些属性,比如:id, item_id, uuid, android, ios。
由于一篇文章会被多个设备浏览,这里的设备ID是唯一的,android和ios字段存储一篇文章在这两个平台的浏览时长,现在想统计的是一篇文章的浏览设备数,平均设备浏览时长,android和ios的总时长。
表例子:

clipboard.png

如果纯SQL语句查询出来的话是这样(只包含浏览人数和总浏览时长):

select *, count(*) as people, sum(android+ios) as `time` from pre_promotion_browse_time group by item_id;

如果用AR类的find方法查询的话:

$articleBrowseTime = new ArticleBrowseTime();
$criteria = new CdbCretira();
$criteria->select = 'item_id, COUNT(*) as people, SUM(android+ios) as time';
$criteria->group = 'item_id';
$article->find($criteria);

这样带来的问题是,我无法查询出文章浏览设备数(people)和文章总浏览时长(time)。因为people字段和time字段并没有在ArticleBrowseTime模型中定义。我知道有人说在这个模型中添加这两个字段就行,但是这两个字段和数据表没关系啊,这种感觉不是很好的设计呢。

所以,怎么才能既使用AR带来的便利方法,又不破坏数据模型的结构,而得到想要的结果?

阅读 2k
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进