數據庫中需要用到join連接查詢時候,用thinkPHP框架的關聯查詢,可以有效的提高查詢效率。(具體查詢性能怎麼樣,咱也沒試過,小夥伴們可以建兩張數據量比較大的表,然後自己測試一下)
thinkPHP5手冊:https://www.kancloud.cn/manual/thinkphp5/135196
hasOne: 一對一關聯
這個沒啥好解釋的。數據之間的關聯一對一。比如:一個用戶表,一個最近登錄表。我們設計之初,每個用戶登錄表只存儲該用戶最近一次的登錄信息。
我們在SUser的模型中這樣寫兩個方法:
public function sLogin()
{
return $this->hasOne('SLogin', 'user_id');
}
public function getLogin()
{
// SLogin 爲關聯表模型的名稱。
return $this
->hasWhere('sLogin', ['create_at' => ['<', '2020-05-15 00:00:00']], 'SUser.last_login_ip, SLogin.visit_ip')
// ->with(['sLogin'])
->paginate(10);
}
控制器裏面進行調用:
$result = (new SUser())->getRole();
return json($result);
就可以看到效果了。
注意:
模型中with和hasWhere的區別是:
使用hasWhere: 可以添加關聯表的查詢條件,並且生成數據的格式和with不同
(下同)
hasMany: 一對多關聯
數據之間的關係一對多,比如:一個用戶有多個用戶資源。
同樣是SUser模型:
public function uSource()
{
// 因爲USource這個類不在當前命名空間,所以這樣寫。
return $this->hasMany('app\index\model\user\USource', 'user_id');
}
public function getSource()
{
return $this
->hasWhere('uSource', ['create_at' => ['<', '2020-05-01 00:00:00']], 'SUser.last_login_ip, USource.img_url')
// ->with(['uSource'])
->where('last_login_ip', '=', '127.0.0.1')
->paginate(10);
}
控制器不用寫了吧。
belongsTo: 屬於
當前方法的模型對應的數據表,屬於另一個模型。相當於多對一。
比如:用戶屬於用戶組。
public function sGroup()
{
return $this->belongsTo('SGroup', 'group_id');
}
public function getGroup()
{
return $this
->hasWhere('sGroup', [], 'SGroup.group_name, SUser.*')
// ->with(['sGroup'])
->where('last_login_ip', '=', '127.0.0.1')
->paginate();
}
belongsToMany: 多對多關聯
這個也不用解釋吧。就是數據之間的關係是多對多。
比如:一個用戶可能又多個角色,一個角色又包含多個用戶。所以他們會有一張中間表,將角色和用戶關聯起來。
public function userRoles()
{
// 第一個參數是當前模型所關聯的另一個模型,第二個參數是關聯中間表的表名,第三個參數是中間表中另一個模型的數據主鍵,最後一個就是當前模型關聯中間表的主鍵。
// 條件如果需要包含中間表的字段,用wherePivot
return $this->belongsToMany('app\index\model\user\URoles', 's_relation', 'role_id', 'user_id')->wherePivot('type', 'eq', 1);
}
public function getRole()
{
return $this
->with(['userRoles'])
->where('last_login_ip', '=', '127.0.0.1')
->paginate(10);
}
也可以多張表一起關聯:
public function getAll()
{
return $this
->with(['userRoles', 'sGroup', 'sLogin', 'uSource'])
->where('last_login_ip', '=', '127.0.0.1')
->paginate(10);
}
就這。沒了。