Yii:属于通过

时间:2012-11-03 09:53:24

标签: php activerecord orm yii

我有3个型号:

Groups
     id
     name

Users
     id
     group_id
     login
     // ....

Messages
     id
     user_id
     title
     body
     // ....

用户属于群组并拥有多条消息

 'group' => array(self::BELONGS_TO, 'Groups', 'group_id'),
 'messages' => array(self::HAS_MANY, 'Messages', 'user_id')

群组有很多用户

 'users' => array(self::HAS_MANY, 'Users', 'group_id')

消息属于用户

 'user' => array(self::BELONGS_TO, 'Users', 'user_id')

属于Yii中的关系没有$through所以如何定义连接消息和组的关系(即消息属于组)?

UPD:肮脏的黑客。定义新的关系类型:

class BelongsToThrough extends CBelongsToRelation {
    public $through;
}

Messages中将其设置为关系类型:

'group' => array('BelongsToThrough', 'Groups', 'group_id', 'through' => 'user')

它有效。不知何故。有人可以解释一下这是如何工作的?

1 个答案:

答案 0 :(得分:0)

也许你可以在消息和组之间建立一个桥接表(groups_messages)并像这样连接它们:

'groups' => array(self::MANY_MANY, 'Groups', 'groups_messages(message_id, group_id)')