thinkPHP5 關聯查詢的使用:hasOne/hasMany/belongsTo/belongsToMany

數據庫中需要用到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);
    }

就這。沒了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章