ThinkPHP3.0完全开发手册
由于性能问题,新版取消了自动关联查询机制,而统一使用relation方法进行关联操作,relation方法不但可以启用关联还可以控制局部关联操作,实现了关联操作一切尽在掌握之中。
$User = D("User");
$user = $User->relation(true)->find(1);
输出$user结果可能是类似于下面的数据:
array(
'id' => 1,
'account' => 'ThinkPHP',
'password' => '123456',
'Profile' => array(
'email' =>'liu21st@gmail.com',
'nickname' =>'流年',
),
)
我们可以看到,用户的关联数据已经被映射到数据对象的属性里面了。其中Profile就是关联定义的mapping_name属性。
如果我们按照下面的凡事定义了as_fields属性的话,
protected $_link = array(
'profile'=>array(
'mapping_type' =>HAS_ONE,
'class_name' =>'Profile',
'foreign_key'=>'userId',
'as_fields'=>'email,nickname',
),
);
查询的结果就变成了下面的结果
array(
'id' => 1,
'account' => 'ThinkPHP',
'password' => 'name',
'email' =>'liu21st@gmail.com',
'nickname' =>'流年',
)
email和nickname两个字段已经作为user数据对象的字段来显示了。
如果关联数据的字段名和当前数据对象的字段有冲突的话,怎么解决呢?
我们可以用下面的方式来变化下定义:
'as_fields'=>'email,nickname:username',
表示关联表的nickname字段映射成当前数据对象的username字段。
默认会把所有定义的关联数据都查询出来,有时候我们并不希望这样,就可以给relation方法传入参数来控制要关联查询的。
$User = D("User");
$user = $User->relation('Profile')->find(1);
关联查询一样可以支持select方法,如果要查询多个数据,并同时获取相应的关联数据,可以改成:
$User = D("User");
$list = $User->relation(true)->Select();
如果希望在完成的查询基础之上 再进行关联数据的查询,可以使用
$User = D("User");
$user = $User->find(1);
// 表示对当前查询的数据对象进行关联数据获取
$profile = $User->relationGet("Profile");
事实上,除了当前的参考模型User外,其他的关联模型是不需要创建的。