如何仅通过一列获取与组关联的数据?

问题描述

我在 postgres 中有三个表。

  • ChatMessages
  • ChatReactions
  • ChatReactionTypes

该关联如下所示:

enter image description here

我正在尝试明智地获取用户反应列表消息。像这个例子。此模式是按消息打开的:

enter image description here

我在 CakePHP 查询生成器中尝试了以下查询

$this->ChatMessages->find()
    ->contain([
        'ChatReactions.ChatReactionTypes',])
    ->contain('ChatReactions',function($q) {
        $q->select([
                'chat_message_id','chat_reaction_type_id','count' => $q->func()->count('chat_reaction_type_id')
        ])
    ->innerJoinWith('ChatReactionTypes')
    ->group(['chat_reaction_type_id','chat_message_id']);
    
        return $q;
    })
    ->order([
        'ChatMessages.created' => 'ASC',])
    ->all()
;

结果如下:

enter image description here

chat_reactions(上图中标记为红色)对象按 react_type_id 分组。我想在 users 中包含与该 ID 关联的所有 chat_reactions

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...