如何3张表相互关联

浏览:1629 发布日期:2014/09/09 分类:求助交流
有用户user,文章message,回复replay,3张表,一个用户对应一篇文章,一篇文章可以被多个用户回复。
message表的userid关联user表的id,replay表的messageid关联message表的id,userid关联用户表的id
需要通过关联模型得到一个用户的所有文章,以及每一篇文章下的回复内容和回复人
$m = D('Message');

$wherecase['userid'] = $_SESSION['userid'];
$arr = $m->relation(array('authors','getRems','repname'))->where($wherecase)->order('mcreatime desc')->select();

结果只能显示文章的作者,回复的内容,但是回复人无法显示,请问关联模型如何支持?

在文章MODEL中建立如下关系
protected $_link=array(
'User'=> array(
'mapping_type'=>BELONGS_TO,
'class_name'=>'User',
'foreign_key'=>'userid',
'mapping_name'=>'authors',
'mapping_fields'=>'uname',
'as_fields'=>'uname:muname',
),

'Replay'=> array(
'mapping_type'=>HAS_MANY,
'class_name'=>'Replay',
'foreign_key'=>'messageid',
'mapping_name'=>'getRems',
'mapping_order'=>'rcreatime desc',

),



);

在回复MODEL建立如下联系
protected $_link=array(

'User'=> array(
'mapping_type'=>BELONGS_TO,
'class_name'=>'User',
'foreign_key'=>'userid',
'mapping_name'=>'repname',
'mapping_fields'=>'uname',
'as_fields'=>'uname:runame',
),


);
最佳答案
评论( 相关
后面还有条评论,点击查看>>