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

发布于 2022-09-11 18:23:41 字数 942 浏览 13 评论 0

问题详情

是这样的,比如我定义了一个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带来的便利方法,又不破坏数据模型的结构,而得到想要的结果?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文