我有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')
它有效。不知何故。有人可以解释一下这是如何工作的?
答案 0 :(得分:0)
也许你可以在消息和组之间建立一个桥接表(groups_messages)并像这样连接它们:
'groups' => array(self::MANY_MANY, 'Groups', 'groups_messages(message_id, group_id)')