場(chǎng)景
用戶之間相互關(guān)注,記錄這種關(guān)系的是followers表(follower_id 發(fā)起關(guān)注的人 followed_id被關(guān)注的人)
現(xiàn)在的多對(duì)多的關(guān)系就不再是傳統(tǒng)的三張表的關(guān)系了, 這種情況 多對(duì)多關(guān)系應(yīng)該怎么聲明呢?
分析
laravel或者其他框架多對(duì)多的關(guān)系 一般都是由Model1 Model2 Model1_Model2(聲明兩者關(guān)系的表)來(lái)組成,
但是上面的場(chǎng)景 卻是只有兩張表,這時(shí)候就要研究下官方文檔了; 當(dāng)然是支持的
參考資料
https://laravel.com/docs/5.6/eloquent-relationships#many-to-many
In addition to customizing the name of the joining table, you may also customize the column names of the keys on the table by passing additional arguments to the belongsToMany method. The third argument is the foreign key name of the model on which you are defining the relationship, while the fourth argument is the foreign key name of the model that you are joining to:
belongsToMany方法傳遞的參數(shù)是可以定制的 以達(dá)到個(gè)性化的需求,
第一個(gè)參數(shù)是 第二個(gè)Model
第二個(gè)參數(shù)是 關(guān)系表名
第三個(gè)參數(shù)是 第一個(gè)Model在關(guān)系表中的外鍵ID
第四個(gè)參數(shù)是 第二個(gè)Model在關(guān)系表中的外鍵ID
解決
經(jīng)過(guò)分析
1. 第一個(gè)Model是User 第一個(gè)Model也是User
2. 關(guān)系表名是 'followers'
/**
* 關(guān)注當(dāng)前用戶的
* @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
*/
public function followers()
{
return $this->belongsToMany(self::class, 'followers', 'followed_id','follower_id')->withTimestamps()
->withTimestamps();
}
/**
* 被當(dāng)前用戶關(guān)注的用戶
*/
public function followed()
{
return $this->belongsToMany(self::class, 'followers', 'follower_id', 'followed_id');
}
以上這篇淺談laravel5.5 belongsToMany自身的正確用法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。