濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > Laravel 模型關(guān)聯(lián)基礎(chǔ)教程詳解

Laravel 模型關(guān)聯(lián)基礎(chǔ)教程詳解

熱門(mén)標(biāo)簽:銅川電話(huà)機(jī)器人價(jià)格 青白江地圖標(biāo)注 聊城電話(huà)外呼系統(tǒng)公司 AI電話(huà)機(jī)器人OEM貼牌 沛縣400電話(huà)辦理 德陽(yáng)中江如何申請(qǐng)400開(kāi)頭電話(huà) 智能電話(huà)機(jī)器人好公司門(mén)薩維 江蘇電商外呼系統(tǒng)運(yùn)營(yíng)商 辦理重慶400電話(huà)

在 Laravel 中定義模型關(guān)聯(lián)是每個(gè) Laravel 開(kāi)發(fā)者可能已經(jīng)做過(guò)不止一次的事情。但是在試圖實(shí)現(xiàn)關(guān)聯(lián)時(shí)可能會(huì)遇到各種問(wèn)題。因?yàn)?Laravel 有各種各樣的關(guān)聯(lián),你應(yīng)該選擇哪一個(gè)?當(dāng)涉及到查詢(xún)模型時(shí),我們?nèi)绾纬浞掷媚P完P(guān)聯(lián)的功能?

Laravel 的模型關(guān)聯(lián)可能會(huì)讓人糊涂。如果你不完全理解 Laravel 的關(guān)聯(lián)在這一點(diǎn)上是如何工作的,別擔(dān)心,讀完這篇文章后,你會(huì)更好地理解它。

我們應(yīng)該使用哪個(gè)模型關(guān)聯(lián)?

要回答這個(gè)問(wèn)題,首先你要知道有哪些可用的選項(xiàng)。Laravel 有 3 種不同的關(guān)聯(lián)類(lèi)型。

  • 一對(duì)一
  • 一對(duì)多
  • 多對(duì)多

我們將逐個(gè)探討不同的關(guān)聯(lián)類(lèi)型并解釋一下應(yīng)該什么時(shí)候使用它們。

一對(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è)用戶(hù)只能擁有一張通行證,同樣,一張通行證也只屬于一個(gè)用戶(hù)。

讓我們看看如何在代碼中定義這種關(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è)你在用戶(hù)模型中定義了 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)。 這種類(lèi)型的關(guān)聯(lián)意味著一個(gè)類(lèi)型A的模型可以鏈接到多個(gè)類(lèi)型B的模型。但是類(lèi)型B的模型只屬于一個(gè)類(lèi)型A的模型。

例如,User 模型和 Invoice 模型之間的關(guān)聯(lián)是一對(duì)多關(guān)聯(lián)。 用戶(hù)可以擁有多個(gè)賬單,但賬單僅屬于一個(gè)用戶(hù)。

在代碼中是這樣寫(xiě)的:

?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)。 這種類(lèi)型的關(guān)聯(lián)意味著類(lèi)型A的一個(gè)模型可以鏈接到類(lèi)型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è)用戶(hù),并且每個(gè)用戶(hù)與一個(gè)用戶(hù)歷史記錄相關(guān)聯(lián),那么供應(yīng)商可以通過(guò)用戶(hù)訪(fǎng)問(wèn)用戶(hù)的歷史記錄。

這就是定義這種關(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)系訪(fǎng)問(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ù)是希望訪(fǎng)問(wèn)模型的名稱(chēng)。 第二個(gè)參數(shù)是中間模型的名稱(chēng)。

遠(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)商模型可以訪(fǎng)問(wèn)產(chǎn)品的歷史記錄條目。

查詢(xún)關(guān)聯(lián)

查詢(xú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);

// 查詢(xún) passport 關(guān)聯(lián)
$user->passport->expiration_date;

// 查詢(xún) invoice 關(guān)聯(lián)
foreach($user->invoices as $invoice) {
  $invoice->total_amount;
}

也可以查詢(xún)關(guān)聯(lián)的反向關(guān)聯(lián)。 如果您有賬單,則可以獲得該賬單的用戶(hù)。

?php
$invoice = \App\Invoice::find(1);
// Get the user
$invoice->user->first_name;

查詢(xún)多對(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;
}

查詢(xún) has one through 和 has many through 的工作方式與其他關(guān)聯(lián)完全相同。

添加約束

可以在查詢(xún)時(shí)向關(guān)系添加約束。看看下面的示例:

?php
$user->passport()->where('active', 1)->orderBy('expiration_date');

檢查關(guān)聯(lián)是否存在

有時(shí)候你希望檢查模型中是否有添加某些關(guān)聯(lián), Laravel有一些方法可以幫助你用來(lái)檢查:

?php
// 找到擁有護(hù)照的所有用戶(hù)
$users = App\User::has('passport')->get();

// 找到?jīng)]擁有護(hù)照的所有用戶(hù)
$users = App\User::doesntHave('passport')->get();

// 找到擁有 5 個(gè)及以上產(chǎn)品的發(fā)票
$invoices = App\Invoice::has('products', '>=', 5)->get();

希望這篇文章能讓你對(duì)Laravel的模型關(guān)聯(lián)有更好的理解。謝謝你的閱讀!也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Laravel 關(guān)聯(lián)模型-關(guān)聯(lián)新增和關(guān)聯(lián)更新的方法
  • Laravel關(guān)聯(lián)模型中過(guò)濾結(jié)果為空的結(jié)果集(has和with區(qū)別)
  • laravel學(xué)習(xí)教程之關(guān)聯(lián)模型
  • Laravel5.1 框架模型多態(tài)關(guān)聯(lián)用法實(shí)例分析
  • Laravel等框架模型關(guān)聯(lián)的可用性淺析
  • Laravel Eloquent分表方法并使用模型關(guān)聯(lián)的實(shí)現(xiàn)
  • Laravel5.1 框架模型遠(yuǎn)層一對(duì)多關(guān)系實(shí)例分析
  • Laravel5.1 框架模型一對(duì)一關(guān)系實(shí)現(xiàn)與使用方法實(shí)例分析
  • Laravel5.1 框架模型查詢(xún)作用域定義與用法實(shí)例分析
  • Laravel5.1 框架模型創(chuàng)建與使用方法實(shí)例分析
  • Laravel5.1 框架關(guān)聯(lián)模型之后操作實(shí)例分析

標(biāo)簽:南寧 迪慶 鷹潭 山南 烏魯木齊 濟(jì)寧 赤峰 三亞

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Laravel 模型關(guān)聯(lián)基礎(chǔ)教程詳解》,本文關(guān)鍵詞  Laravel,模型,關(guān)聯(lián),基礎(chǔ),教程,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Laravel 模型關(guān)聯(lián)基礎(chǔ)教程詳解》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于Laravel 模型關(guān)聯(lián)基礎(chǔ)教程詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    保靖县| 祁门县| 新干县| 务川| 南郑县| 迁西县| 繁昌县| 缙云县| 紫云| 什邡市| 即墨市| 凤城市| 天等县| 吉木乃县| 乐陵市| 托里县| 赣榆县| 祁阳县| 景洪市| 丰台区| 新昌县| 浦北县| 会理县| 玉树县| 深圳市| 永嘉县| 靖江市| 东乌珠穆沁旗| 隆回县| 威海市| 永修县| 汾西县| 于田县| 阳山县| 隆昌县| 海南省| 德江县| 盱眙县| 福鼎市| 贺兰县| 浙江省|