TP5中 经常要连表查用的是with,with熟练使用可以快速完成编程。
with在controller 中的常见用法:
$data = \app\admin\model\patients\Patients::where("id", $id)
->with(["room", "bed", "clinical"])
->find();
?同时在model中的Patients.php需要添加:
public function clinical()
{
return $this->hasOne('Clinical', "id", "clinical_id");
}
public function room()
{
return $this->hasOne('app\admin\model\space\Info', "id", "space_id");
}
public function bed()
{
return $this->hasOne('app\admin\model\space\Bed', "id", "bed_id");
}
当然也可以多个表联查,例如:
$data = \app\admin\model\Document::order('type')
->where($where)
->where('status',1)
->with(['file.user','user'])
->paginate($pagesize);
在model中的Document.php页面中添加:
public function file()
{
return $this->hasOne(File::class, 'id', 'file_id');
}
public function user()
{
return $this->hasOne(User::class, 'id', 'user_id')->field("id,username,nickname,prevtime,logintime,jointime");
}
在model中的File.php页面中添加:
public function user()
{
return $this->hasOne(User::class, 'id', 'user_id')->field("id,username,nickname,prevtime,logintime,jointime");
}
常见的关联查询的使用:hasOne/hasMany/belongsTo
hasOne:?一对一关联
数据之间的关联一对一。例如:一个file表里面的上传人对应一个user表中的user信息。
hasOne('别的表模型名','别的表外键名','本表主键名',['模型别名定义'],'join类型');
public function user(){
return $this->hasOne(User::class, 'id', 'create_id')->field("id,username");
}
hasMany:?一对多关联
数据之间的关联一对多。例如:一个user表里面的上传文件对应file表中的多个file。?
?withcount用法:
$rows = \app\admin\model\UserGroup::where($map)
->with(['department','user'])
->withCount('linkUser')
->paginate($pageSize);
public function department(){
return $this->belongsTo(Department::class,"department_id","id")->field('id,name');
}
public function linkUser(){
return $this->hasMany(UserLinkGroup::class,"gid","id");
}
public function user(){
return $this->hasOne(User::class, 'id', 'create_id')->field("id,username");
}
belongsTo:属于
当前方法的模型对应的数据表,属于另一个模型。相当于多对一。
belongsTo('别的表模型名','本表外键名','本表关联表主键名',['模型别名定义'],'join类型');
public function department(){
return $this->belongsTo(Department::class,"department_id","id")->field('id,name');
}
深入写法:
添加一些条件语句查询:
$data = CategoryModel::with(['files' => function($q) use ($unVisibleFileIds){
$q->where('id','not in', $unVisibleFileIds)->where('status','1')->where('pid',0);
}])->where($map)->select();
|