亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2019年09月17日 11:38:44   作者:Charlie_Jade  
這篇文章主要介紹了Laravel 模型關(guān)聯(lián)基礎(chǔ)教程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

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

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

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

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

  • 一對一
  • 一對多
  • 多對多

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

一對一

一對一關(guān)聯(lián)是目前存在的最基本的關(guān)聯(lián)。這種關(guān)聯(lián)意味著 A 模型只能鏈接到 B 模型,相反也是如此。舉個例子,一個 User 模型和一個 Passport 模型會成為一對一的關(guān)聯(lián)。一個用戶只能擁有一張通行證,同樣,一張通行證也只屬于一個用戶。

讓我們看看如何在代碼中定義這種關(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)建了一個 passport 方法。我們通過 hasOne 方法告訴 Laravel User 模型有一個 Passport 。

注意:
所有用于定義關(guān)聯(lián)的方法都有可選的額外參數(shù),你可以在這些參數(shù)中定義本地鍵和外鍵。默認情況下,Laravel會假設(shè)你在用戶模型中定義了 passport_id ,因為你試圖創(chuàng)建與 passport 模型的關(guān)聯(lián)。創(chuàng)建遷移文件時也請注意這一點!

在 Passport 模型中,我們需要定義逆向的關(guān)聯(lián)。我們要讓 Passport 模型知道它屬于 User 模型。我們可以使用 belongsTo 方法來實現(xiàn)這一點。

<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Passport extends Model
{
  public function user() {
    return $this->belongsTo(App\User::class);
  }
}

一對多

你可以在 Laravel 中定義的下一個關(guān)聯(lián)是一對多關(guān)聯(lián)。 這種類型的關(guān)聯(lián)意味著一個類型A的模型可以鏈接到多個類型B的模型。但是類型B的模型只屬于一個類型A的模型。

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

在代碼中是這樣寫的:

<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
  public function invoices() {
    return $this->hasMany(App\Invoice::class);
  }
}

它看起來就像我們之前用于定義一對一關(guān)聯(lián)的代碼,對吧?

我們現(xiàn)在要做的就是讓 Invoice 模型知道它屬于 User 模型。 讓我們定義一對多關(guān)聯(lián)的反向?qū)P(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);
  }
}

多對多

最后要定義的關(guān)聯(lián)是多對多關(guān)聯(lián)。 這種類型的關(guān)聯(lián)意味著類型A的一個模型可以鏈接到類型B的多個模型,反之亦然。

例如,Invoice  模型和 Product  模型之間的關(guān)聯(lián)將是多對多關(guān)聯(lián)。 賬單可以包含多個產(chǎn)品,而產(chǎn)品可以屬于多個賬單。

<?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);
  }
}

多對多關(guān)聯(lián)實現(xiàn)起來稍微困難一些,因為它們需要數(shù)據(jù)庫中的中間表。 你可以通過創(chuàng)建遷移文件在 Laravel 中創(chuàng)建此中間表。

遠程關(guān)聯(lián)

遠程一對一

has one through 關(guān)聯(lián)通過單個中間關(guān)聯(lián)模型實現(xiàn)。 如果每個供應商都有一個用戶,并且每個用戶與一個用戶歷史記錄相關(guān)聯(lián),那么供應商可以通過用戶訪問用戶的歷史記錄。

這就是定義這種關(guān)聯(lián)所需的數(shù)據(jù)庫表:

suppliers:
- idproducts:
- id
- supplier_idproduct_history:
- id
- product_id

即使 product_history 表不包含 supplier_id 列,供應商也可以通過使用 「has one through」 關(guā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 方法的第一個參數(shù)是希望訪問模型的名稱。 第二個參數(shù)是中間模型的名稱。

遠程一對多

「has many through」 關(guān)聯(lián)相當于 「has one through」 關(guān)聯(lián),只是對于多個記錄的。 讓我們使用前面的示例,但我們改變一件事:產(chǎn)品現(xiàn)在可以有多個歷史條目而不是一個。 數(shù)據(jù)庫表保持不變。

<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Supplier extends Model
{
  public function productHistory() {
    return $this->hasManyThrough(App\History::class, App\Product::class);
  }
}

這樣,供應商模型可以訪問產(chǎn)品的歷史記錄條目。

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

查詢一個關(guān)聯(lián)非常簡單。因為我們定義了 Passport 的一對一關(guān)聯(lián)和 Invoice 的一對多關(guān)聯(lián),所以我們可以在 User 模型中使用它們。在 User 模型的每個實例上,我們都可以得到對應的 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;

查詢多對多關(guān)聯(lián)的工作方式與其他關(guān)聯(lián)完全相同。 此外,多對多關(guān)聯(lián)有一個pivot 屬性。 此屬性表示中間表,可以像任何其他模型一樣使用。

舉個例子,假設(shè)連接的表有 created_at 字段,我們就可以使用 pivot 來獲取 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)完全相同。

添加約束

可以在查詢時向關(guān)系添加約束??纯聪旅娴氖纠?/p>

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

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

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

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

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

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

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

  • YII框架實現(xiàn)自定義第三方擴展操作示例

    YII框架實現(xiàn)自定義第三方擴展操作示例

    這篇文章主要介紹了YII框架實現(xiàn)自定義第三方擴展操作,結(jié)合實例形式分析了Yii框架自定義第三方擴展操作的步驟與相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2019-04-04
  • Yii2.0高級框架數(shù)據(jù)庫增刪改查的一些操作

    Yii2.0高級框架數(shù)據(jù)庫增刪改查的一些操作

    yii2.0框架是PHP開發(fā)的一個比較高效率的框架,集合了作者的大量心血,下面通過用戶為例給大家詳解yii2.0高級框架數(shù)據(jù)庫增刪改查的一些操作
    2015-11-11
  • PHP遠程采集圖片詳細教程

    PHP遠程采集圖片詳細教程

    這篇文章主要介紹了PHP遠程采集圖片詳細教程,一步一步實現(xiàn)圖片的采集功能,簡單的入門教程,需要的朋友可以參考下
    2014-07-07
  • PHP基于SMTP協(xié)議實現(xiàn)郵件發(fā)送實例代碼

    PHP基于SMTP協(xié)議實現(xiàn)郵件發(fā)送實例代碼

    本篇文章主要介紹了PHP基于SMTP協(xié)議實現(xiàn)郵件發(fā)送實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • PHP框架Laravel中使用UUID實現(xiàn)數(shù)據(jù)分表操作示例

    PHP框架Laravel中使用UUID實現(xiàn)數(shù)據(jù)分表操作示例

    這篇文章主要介紹了PHP框架Laravel中使用UUID實現(xiàn)數(shù)據(jù)分表操作,結(jié)合實例形式較為詳細的分析了Laravel框架基于UUID進行數(shù)據(jù)分表的相關(guān)操作步驟、實現(xiàn)技巧與操作注意事項,需要的朋友可以參考下
    2018-05-05
  • thinkPHP交易詳情查詢功能詳解

    thinkPHP交易詳情查詢功能詳解

    這篇文章主要介紹了thinkPHP交易詳情查詢功能,結(jié)合實例形式分析了thinkPHP數(shù)據(jù)庫查詢功能及視圖輸出相關(guān)操作技巧,需要的朋友可以參考下
    2016-12-12
  • Laravel 5框架學習之Eloquent (laravel 的ORM)

    Laravel 5框架學習之Eloquent (laravel 的ORM)

    Laravel 的 Eloquent ORM 提供了漂亮、簡潔的 ActiveRecord 實現(xiàn)來和數(shù)據(jù)庫的互動。 每個數(shù)據(jù)庫表會和一個對應的「模型」互動。在開始之前,記得把 config/database.php 里的數(shù)據(jù)庫連接配置好。
    2015-04-04
  • Thinkphp5+Redis實現(xiàn)商品秒殺代碼實例講解

    Thinkphp5+Redis實現(xiàn)商品秒殺代碼實例講解

    這篇文章主要介紹了Thinkphp5+Redis實現(xiàn)商品秒殺代碼實例講解,代碼和步驟講解的很清楚,有需要的同學可以借鑒參考下
    2020-12-12
  • Yii2創(chuàng)建控制器(createController)方法詳解

    Yii2創(chuàng)建控制器(createController)方法詳解

    這篇文章主要介紹了Yii2創(chuàng)建控制器(createController)的方法,結(jié)合實例形式分析了Yii創(chuàng)建控制器所使用到的方法、操作步驟與相關(guān)技巧,需要的朋友可以參考下
    2016-07-07
  • 最新評論