视图在有些数据库下面并不被支持,但是ThinkPHP模拟实现了数据库的视图,该功能可以用于多表联合查询。非常适合解决HAS_ONE 和 BELONGS_TO类型的关联查询。
要定义视图模型,只需要继承ViewModel,然后设置viewFields属性即可。
class BlogViewModel extends ViewModel
{
public $viewFields = array(
'Blog'=>array('id','name','title'),
'Category'=>array('title'=>'category_name', '_on'=>'Blog.category_id=Category.id'),
'User'=>array('name'=>'username', '_on'=>'Blog.user_id=User.id'),
);
}
$viewFields 属性表示视图模型包含的字段,每个元素定义了某个数据表或者模型的字段。
'Category'=>array('title'=>'category_name')
和上面类似,表示BlogView视图模型还要包含Category模型的title字段,因为视图模型里面已经存在了一个title字段,所以我们通过
'title'=>'category_name'
把Category模型的title字段映射为category_name字段,如果有多个字段,可以使用同样的方式添加。可以通过_on来给视图模型定义关联查询条件,例如:
'_on'=>'Blog.category_id=Category.id'
理解之后,User模型的定义方式同样也就很容易理解了。