在Yii1(或Yii2)中,AR类的find方法返回未被定义的字段,如何才能让这个字段在结果集中显示出来?
问题详情
是这样的,比如我定义了一个AR类,叫ArticleBrowseTime,定义了一些属性,比如:id, item_id, uuid, android, ios。
由于一篇文章会被多个设备浏览,这里的设备ID是唯一的,android和ios字段存储一篇文章在这两个平台的浏览时长,现在想统计的是一篇文章的浏览设备数,平均设备浏览时长,android和ios的总时长。
表例子:
如果纯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带来的便利方法,又不破坏数据模型的结构,而得到想要的结果?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论