由于性能问题,ThinkPHP3.2.3新版取消了自动关联查询机制,而统一使用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' => self::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外,其他的关联模型是不需要创建的。