本文實例講述了Laravel5.1 框架模型遠層一對多關系。分享給大家供大家參考,具體如下:
遠層一對多我們可以通過一個例子來充分的了解它:
每一篇文章都肯定有并且只有一個發布者 發布者可以有多篇文章,這是一個一對多的關系。一個發布者可以來自于一個國家 但是一個國家可以有多個發布者,這又是一個一對多關系,那么 這其中存在一個遠層的一對多就是"國家和文章的關系"。國家表可以通過發布者表遠層關聯到文章表。
1 實現遠層一對多關系
1.1 文章表結構
public function up()
{
Schema::create('articles', function (Blueprint $table) {
$table->increments('id');
$table->string('title');
$table->text('body');
$table->integer('user_id');
$table->timestamps();
});
}
1.2 在users表中添加一列
public function up()
{
Schema::table('users', function (Blueprint $table) {
$table->integer('country_id');
});
}
public function down()
{
Schema::table('users', function (Blueprint $table) {
$table->dropColumn('country_id');
});
}
1.3 國家表結構
public function up()
{
Schema::create('countries', function (Blueprint $table) {
$table->increments('id');
$table->string('name');
$table->timestamps();
});
}
1.4 編寫一對多關系
首先是Country和User的關系:
Country模型:
public function users()
{
return $this->hasMany(User::class);
}
User模型:
public function country()
{
return $this->belongsTo(Country::class);
}
然后是User和Article的關系:
User模型:
public function articles()
{
return $this->hasMany(Article::class);
}
Article模型:
public function user()
{
return $this->belongsTo(User::class);
}
1.5 訪問遠程一對多關系
這是今天的主要內容,實現Country可遠層查找到Article:
public function articles()
{
/**
* 建議第一個和第二個參數寫全,第三個第四個參數可省略使用默認(如果默認的沒問題)。
*/
return $this->hasManyThrough(Article::class, User::class, 'country_id', 'user_id');
}
更多關于Laravel相關內容感興趣的讀者可查看本站專題:《Laravel框架入門與進階教程》、《php優秀開發框架總結》、《php面向對象程序設計入門教程》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家基于Laravel框架的PHP程序設計有所幫助。
您可能感興趣的文章:- 在laravel中實現ORM模型使用第二個數據庫設置
- 使用laravel的Eloquent模型如何獲取數據庫的指定列
- Laravel5.1 框架關聯模型之后操作實例分析
- Laravel5.1 框架模型多態關聯用法實例分析
- Laravel5.1 框架模型一對一關系實現與使用方法實例分析
- Laravel5.1 框架模型查詢作用域定義與用法實例分析
- Laravel5.1 框架模型軟刪除操作實例分析
- Laravel5.1 框架模型創建與使用方法實例分析
- Laravel框架視圖和模型操作方法分析
- Laravel 5框架學習之模型、控制器、視圖基礎流程
- laravel學習教程之關聯模型
- laravel框架模型和數據庫基礎操作實例詳解