本篇文章給大家分享的是有關(guān)使用Laravel怎么實(shí)現(xiàn)模型關(guān)聯(lián),小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。
創(chuàng)新互聯(lián)建站主營(yíng)華龍網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,app軟件開發(fā),華龍h5重慶小程序開發(fā)搭建,華龍網(wǎng)站營(yíng)銷推廣歡迎華龍等地區(qū)企業(yè)咨詢一對(duì)一
一對(duì)一關(guān)聯(lián)是目前存在的最基本的關(guān)聯(lián)。這種關(guān)聯(lián)意味著 A 模型只能鏈接到 B 模型,相反也是如此。舉個(gè)例子,一個(gè) User 模型和一個(gè) Passport 模型會(huì)成為一對(duì)一的關(guān)聯(lián)。一個(gè)用戶只能擁有一張通行證,同樣,一張通行證也只屬于一個(gè)用戶。
讓我們看看如何在代碼中定義這種關(guān)聯(lián)。
<?php namespace App; use Illuminate\Database\Eloquent\Model; class User extends Model { public function passport() { return $this->hasOne(App\Passport::class); } }
在 User 模型中我們創(chuàng)建了一個(gè) passport 方法。我們通過(guò) hasOne 方法告訴 Laravel User 模型有一個(gè) Passport 。
注意:
所有用于定義關(guān)聯(lián)的方法都有可選的額外參數(shù),你可以在這些參數(shù)中定義本地鍵和外鍵。默認(rèn)情況下,Laravel會(huì)假設(shè)你在用戶模型中定義了 passport_id ,因?yàn)槟阍噲D創(chuàng)建與 passport 模型的關(guān)聯(lián)。創(chuàng)建遷移文件時(shí)也請(qǐng)注意這一點(diǎn)!
在 Passport 模型中,我們需要定義逆向的關(guān)聯(lián)。我們要讓 Passport 模型知道它屬于 User 模型。我們可以使用 belongsTo 方法來(lái)實(shí)現(xiàn)這一點(diǎn)。
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Passport extends Model { public function user() { return $this->belongsTo(App\User::class); } }
一對(duì)多
你可以在 Laravel 中定義的下一個(gè)關(guān)聯(lián)是一對(duì)多關(guān)聯(lián)。 這種類型的關(guān)聯(lián)意味著一個(gè)類型A的模型可以鏈接到多個(gè)類型B的模型。但是類型B的模型只屬于一個(gè)類型A的模型。
例如,User 模型和 Invoice 模型之間的關(guān)聯(lián)是一對(duì)多關(guān)聯(lián)。 用戶可以擁有多個(gè)賬單,但賬單僅屬于一個(gè)用戶。
在代碼中是這樣寫的:
<?php namespace App; use Illuminate\Database\Eloquent\Model; class User extends Model { public function invoices() { return $this->hasMany(App\Invoice::class); } }
它看起來(lái)就像我們之前用于定義一對(duì)一關(guān)聯(lián)的代碼,對(duì)吧?
我們現(xiàn)在要做的就是讓 Invoice 模型知道它屬于 User 模型。 讓我們定義一對(duì)多關(guān)聯(lián)的反向?qū)?yīng)關(guān)聯(lián)吧。
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Invoice extends Model { public function user() { return $this->belongsTo(App\User::class); } }
多對(duì)多
最后要定義的關(guān)聯(lián)是多對(duì)多關(guān)聯(lián)。 這種類型的關(guān)聯(lián)意味著類型A的一個(gè)模型可以鏈接到類型B的多個(gè)模型,反之亦然。
例如,Invoice 模型和 Product 模型之間的關(guān)聯(lián)將是多對(duì)多關(guān)聯(lián)。 賬單可以包含多個(gè)產(chǎn)品,而產(chǎn)品可以屬于多個(gè)賬單。
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Invoice extends Model { public function products() { return $this->belongsToMany(App\Product::class); } }
你可以像這樣定義這種關(guān)聯(lián)的反向關(guān)系:
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Product extends Model { public function invoices() { return $this->belongsToMany(App\Invoice::class); } }
多對(duì)多關(guān)聯(lián)實(shí)現(xiàn)起來(lái)稍微困難一些,因?yàn)樗鼈冃枰獢?shù)據(jù)庫(kù)中的中間表。 你可以通過(guò)創(chuàng)建遷移文件在 Laravel 中創(chuàng)建此中間表。
遠(yuǎn)程關(guān)聯(lián)
遠(yuǎn)程一對(duì)一
has one through 關(guān)聯(lián)通過(guò)單個(gè)中間關(guān)聯(lián)模型實(shí)現(xiàn)。 如果每個(gè)供應(yīng)商都有一個(gè)用戶,并且每個(gè)用戶與一個(gè)用戶歷史記錄相關(guān)聯(lián),那么供應(yīng)商可以通過(guò)用戶訪問(wèn)用戶的歷史記錄。
這就是定義這種關(guān)聯(lián)所需的數(shù)據(jù)庫(kù)表:
suppliers: - idproducts: - id - supplier_idproduct_history: - id - product_id
即使 product_history 表不包含 supplier_id 列,供應(yīng)商也可以通過(guò)使用 「has one through」 關(guān)系訪問(wèn) product_history 記錄。
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Supplier extends Model { public function productHistory() { return $this->hasOneThrough(App\History::class, App\Product::class); } }
傳遞給 hasOneThrough 方法的第一個(gè)參數(shù)是希望訪問(wèn)模型的名稱。 第二個(gè)參數(shù)是中間模型的名稱。
遠(yuǎn)程一對(duì)多
「has many through」 關(guān)聯(lián)相當(dāng)于 「has one through」 關(guān)聯(lián),只是對(duì)于多個(gè)記錄的。 讓我們使用前面的示例,但我們改變一件事:產(chǎn)品現(xiàn)在可以有多個(gè)歷史條目而不是一個(gè)。 數(shù)據(jù)庫(kù)表保持不變。
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Supplier extends Model { public function productHistory() { return $this->hasManyThrough(App\History::class, App\Product::class); } }
這樣,供應(yīng)商模型可以訪問(wèn)產(chǎn)品的歷史記錄條目。
查詢關(guān)聯(lián)
查詢一個(gè)關(guān)聯(lián)非常簡(jiǎn)單。因?yàn)槲覀兌x了 Passport 的一對(duì)一關(guān)聯(lián)和 Invoice 的一對(duì)多關(guān)聯(lián),所以我們可以在 User 模型中使用它們。在 User 模型的每個(gè)實(shí)例上,我們都可以得到對(duì)應(yīng)的 Passport 和 Invoice。
<?php $user = \App\User::find(1); // 查詢 passport 關(guān)聯(lián) $user->passport->expiration_date; // 查詢 invoice 關(guān)聯(lián) foreach($user->invoices as $invoice) { $invoice->total_amount; }
也可以查詢關(guān)聯(lián)的反向關(guān)聯(lián)。 如果您有賬單,則可以獲得該賬單的用戶。
<?php $invoice = \App\Invoice::find(1); // Get the user $invoice->user->first_name;
查詢多對(duì)多關(guān)聯(lián)的工作方式與其他關(guān)聯(lián)完全相同。 此外,多對(duì)多關(guān)聯(lián)有一個(gè)pivot 屬性。 此屬性表示中間表,可以像任何其他模型一樣使用。
舉個(gè)例子,假設(shè)連接的表有 created_at 字段,我們就可以使用 pivot 來(lái)獲取 created_at 字段。
<?php $invoice = \App\Invoice::find(1); // 獲取 product 的 `created_at` 字段 foreach($invoice->products as $product) { $product->pivot->created_at; }
查詢 has one through 和 has many through 的工作方式與其他關(guān)聯(lián)完全相同。
添加約束
可以在查詢時(shí)向關(guān)系添加約束??纯聪旅娴氖纠?/p>
<?php $user->passport()->where('active', 1)->orderBy('expiration_date');
檢查關(guān)聯(lián)是否存在
有時(shí)候你希望檢查模型中是否有添加某些關(guān)聯(lián), Laravel有一些方法可以幫助你用來(lái)檢查:
<?php // 找到擁有護(hù)照的所有用戶 $users = App\User::has('passport')->get(); // 找到?jīng)]擁有護(hù)照的所有用戶 $users = App\User::doesntHave('passport')->get(); // 找到擁有 5 個(gè)及以上產(chǎn)品的發(fā)票 $invoices = App\Invoice::has('products', '>=', 5)->get();
以上就是使用Laravel怎么實(shí)現(xiàn)模型關(guān)聯(lián),小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
新聞名稱:使用Laravel怎么實(shí)現(xiàn)模型關(guān)聯(lián)-創(chuàng)新互聯(lián)
網(wǎng)址分享:http://muchs.cn/article18/phpgp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供手機(jī)網(wǎng)站建設(shè)、品牌網(wǎng)站建設(shè)、App開發(fā)、外貿(mào)建站、外貿(mào)網(wǎng)站建設(shè)、面包屑導(dǎo)航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容