Laravel5.1 框架模型遠(yuǎn)層一對多關(guān)系實(shí)例分析
本文實(shí)例講述了Laravel5.1 框架模型遠(yuǎn)層一對多關(guān)系。分享給大家供大家參考,具體如下:
遠(yuǎn)層一對多我們可以通過一個例子來充分的了解它:
每一篇文章都肯定有并且只有一個發(fā)布者 發(fā)布者可以有多篇文章,這是一個一對多的關(guān)系。一個發(fā)布者可以來自于一個國家 但是一個國家可以有多個發(fā)布者,這又是一個一對多關(guān)系,那么 這其中存在一個遠(yuǎn)層的一對多就是"國家和文章的關(guān)系"。國家表可以通過發(fā)布者表遠(yuǎn)層關(guān)聯(lián)到文章表。
1 實(shí)現(xiàn)遠(yuǎn)層一對多關(guān)系
1.1 文章表結(jié)構(gòu)
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 國家表結(jié)構(gòu)
public function up()
{
Schema::create('countries', function (Blueprint $table) {
$table->increments('id');
$table->string('name');
$table->timestamps();
});
}
1.4 編寫一對多關(guān)系
首先是Country和User的關(guān)系:
Country模型:
public function users()
{
return $this->hasMany(User::class);
}
User模型:
public function country()
{
return $this->belongsTo(Country::class);
}
然后是User和Article的關(guān)系:
User模型:
public function articles()
{
return $this->hasMany(Article::class);
}
Article模型:
public function user()
{
return $this->belongsTo(User::class);
}
1.5 訪問遠(yuǎn)程一對多關(guān)系
這是今天的主要內(nèi)容,實(shí)現(xiàn)Country可遠(yuǎn)層查找到Article:
public function articles()
{
/**
* 建議第一個和第二個參數(shù)寫全,第三個第四個參數(shù)可省略使用默認(rèn)(如果默認(rèn)的沒問題)。
*/
return $this->hasManyThrough(Article::class, User::class, 'country_id', 'user_id');
}
更多關(guān)于Laravel相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進(jìn)階教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家基于Laravel框架的PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
php實(shí)現(xiàn)生成帶二維碼圖片并強(qiáng)制下載功能
這篇文章主要介紹了php生成帶二維碼圖片并強(qiáng)制下載實(shí)現(xiàn)代碼,需要的朋友可以參考下2018-02-02
Smarty緩存機(jī)制實(shí)例詳解【三種緩存方式】
這篇文章主要介紹了Smarty緩存機(jī)制,結(jié)合實(shí)例形式詳細(xì)分析了Smarty全局緩存、部分緩存及局部緩存三種緩存實(shí)現(xiàn)方式,并附帶說明了Smarty清除緩存的實(shí)現(xiàn)方式,需要的朋友可以參考下2019-07-07
Yii框架實(shí)現(xiàn)對數(shù)據(jù)庫的CURD操作示例
這篇文章主要介紹了Yii框架實(shí)現(xiàn)對數(shù)據(jù)庫的CURD操作,結(jié)合實(shí)例形式分析了Yii框架連接數(shù)據(jù)庫與CURD增刪改查等常見操作技巧,需要的朋友可以參考下2019-09-09
tp5(thinkPHP5)框架實(shí)現(xiàn)多數(shù)據(jù)庫查詢的方法
這篇文章主要介紹了tp5(thinkPHP5)框架實(shí)現(xiàn)多數(shù)據(jù)庫查詢的方法,結(jié)合實(shí)例形式分析了thinkPHP5框架多數(shù)據(jù)庫查詢的相關(guān)配置、初始化及調(diào)用相關(guān)操作技巧,需要的朋友可以參考下2019-01-01

