婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Laravel 模型關聯基礎教程詳解

Laravel 模型關聯基礎教程詳解

熱門標簽:銅川電話機器人價格 青白江地圖標注 聊城電話外呼系統公司 AI電話機器人OEM貼牌 沛縣400電話辦理 德陽中江如何申請400開頭電話 智能電話機器人好公司門薩維 江蘇電商外呼系統運營商 辦理重慶400電話

在 Laravel 中定義模型關聯是每個 Laravel 開發者可能已經做過不止一次的事情。但是在試圖實現關聯時可能會遇到各種問題。因為 Laravel 有各種各樣的關聯,你應該選擇哪一個?當涉及到查詢模型時,我們如何充分利用模型關聯的功能?

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

我們應該使用哪個模型關聯?

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

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

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

一對一

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

讓我們看看如何在代碼中定義這種關聯。

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

在 User 模型中我們創建了一個 passport 方法。我們通過 hasOne 方法告訴 Laravel User 模型有一個 Passport 。

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

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

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

一對多

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

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

在代碼中是這樣寫的:

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

它看起來就像我們之前用于定義一對一關聯的代碼,對吧?

我們現在要做的就是讓 Invoice 模型知道它屬于 User 模型。 讓我們定義一對多關聯的反向對應關聯吧。

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

多對多

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

例如,Invoice  模型和 Product  模型之間的關聯將是多對多關聯。 賬單可以包含多個產品,而產品可以屬于多個賬單。

?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Invoice extends Model
{
  public function products() {
    return $this->belongsToMany(App\Product::class);
  }
}

你可以像這樣定義這種關聯的反向關系:

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

多對多關聯實現起來稍微困難一些,因為它們需要數據庫中的中間表。 你可以通過創建遷移文件在 Laravel 中創建此中間表。

遠程關聯

遠程一對一

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

這就是定義這種關聯所需的數據庫表:

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

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

遠程一對多

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

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

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

查詢關聯

查詢一個關聯非常簡單。因為我們定義了 Passport 的一對一關聯和 Invoice 的一對多關聯,所以我們可以在 User 模型中使用它們。在 User 模型的每個實例上,我們都可以得到對應的 Passport 和 Invoice。

?php
$user = \App\User::find(1);

// 查詢 passport 關聯
$user->passport->expiration_date;

// 查詢 invoice 關聯
foreach($user->invoices as $invoice) {
  $invoice->total_amount;
}

也可以查詢關聯的反向關聯。 如果您有賬單,則可以獲得該賬單的用戶。

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

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

舉個例子,假設連接的表有 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 的工作方式與其他關聯完全相同。

添加約束

可以在查詢時向關系添加約束。看看下面的示例:

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

檢查關聯是否存在

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

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

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

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

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

您可能感興趣的文章:
  • Laravel 關聯模型-關聯新增和關聯更新的方法
  • Laravel關聯模型中過濾結果為空的結果集(has和with區別)
  • laravel學習教程之關聯模型
  • Laravel5.1 框架模型多態關聯用法實例分析
  • Laravel等框架模型關聯的可用性淺析
  • Laravel Eloquent分表方法并使用模型關聯的實現
  • Laravel5.1 框架模型遠層一對多關系實例分析
  • Laravel5.1 框架模型一對一關系實現與使用方法實例分析
  • Laravel5.1 框架模型查詢作用域定義與用法實例分析
  • Laravel5.1 框架模型創建與使用方法實例分析
  • Laravel5.1 框架關聯模型之后操作實例分析

標簽:南寧 迪慶 鷹潭 山南 烏魯木齊 濟寧 赤峰 三亞

巨人網絡通訊聲明:本文標題《Laravel 模型關聯基礎教程詳解》,本文關鍵詞  Laravel,模型,關聯,基礎,教程,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Laravel 模型關聯基礎教程詳解》相關的同類信息!
  • 本頁收集關于Laravel 模型關聯基礎教程詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    五月婷婷激情综合| 一本大道久久a久久精二百| 日韩一级成人av| 在线观看视频一区| www.av亚洲| 91免费视频观看| 日本道精品一区二区三区| 色综合久久六月婷婷中文字幕| 亚洲欧洲精品一区二区三区 | 日韩免费在线观看| 成人黄色网址在线观看| 成人av网在线| 欧美日韩一区 二区 三区 久久精品| 国产精品一区二区视频| 美女网站在线免费欧美精品| 麻豆成人免费电影| 2020国产精品久久精品美国| 亚洲影视在线播放| 91丝袜高跟美女视频| 亚洲精品中文在线影院| 91九色02白丝porn| 蜜臀av国产精品久久久久| 99精品欧美一区二区蜜桃免费| 欧美中文字幕久久| 日本不卡视频在线| 精品婷婷伊人一区三区三| 青青青爽久久午夜综合久久午夜| www.色综合.com| 亚洲一区二三区| 精品福利av导航| 色婷婷av一区二区三区gif| 免费看日韩精品| 亚洲男同1069视频| 精品成人佐山爱一区二区| 欧美性做爰猛烈叫床潮| 国产福利精品一区二区| 日韩国产一区二| 樱桃国产成人精品视频| 欧美国产精品中文字幕| 6080日韩午夜伦伦午夜伦| 亚洲一二三四区不卡| 久久久久久毛片| 337p亚洲精品色噜噜狠狠| 91在线观看视频| 国产白丝精品91爽爽久久| 免费观看30秒视频久久| 亚洲一区二区四区蜜桃| 国产精品国产精品国产专区不蜜| 国产成人免费视频一区| 日本特黄久久久高潮| 亚洲综合一二区| 亚洲精品日产精品乱码不卡| 久久久久9999亚洲精品| 91精品久久久久久久久99蜜臂| 午夜精品久久久久久久久| 欧美伊人久久久久久久久影院| 亚洲欧美日韩国产一区二区三区 | 成人国产一区二区三区精品| 久久久久久久性| 欧美精品日韩一本| 色94色欧美sute亚洲线路一久 | 自拍偷拍国产精品| 不卡的av电影| 亚洲欧美另类小说| 国产欧美日韩三级| 国产免费观看久久| 国产三级精品三级| 国产亚洲精品久| 中日韩免费视频中文字幕| 久久综合狠狠综合久久激情| 精品国产免费一区二区三区香蕉| 丰满放荡岳乱妇91ww| 国产精品综合久久| 成人免费毛片嘿嘿连载视频| 波多野结衣亚洲一区| eeuss国产一区二区三区| 亚洲一区二区成人在线观看| 7777精品伊人久久久大香线蕉最新版 | 色婷婷久久久久swag精品 | 欧美少妇性性性| 欧美天堂一区二区三区| 欧美精品 国产精品| 日韩精品一区二区在线| 国产人成一区二区三区影院| 欧美亚洲国产一区在线观看网站 | 日本一区二区三区在线观看| 久久久精品tv| 欧美日韩一区在线观看| 欧美日韩日本视频| 欧美精品一区二区高清在线观看 | 丁香啪啪综合成人亚洲小说| 成人国产视频在线观看| 欧美亚洲国产一卡| 26uuu亚洲| 一区二区三区四区激情| 久久电影网电视剧免费观看| av电影天堂一区二区在线观看| 午夜激情久久久| 国产精品萝li| 樱桃视频在线观看一区| 美女任你摸久久| 日本伊人色综合网| 国产91精品入口| 欧美亚洲日本国产| 一本色道**综合亚洲精品蜜桃冫| 韩国理伦片一区二区三区在线播放| 亚洲国产视频直播| 精品一区二区在线免费观看| 日本韩国欧美在线| 色悠悠亚洲一区二区| 欧美一二三四区在线| 亚洲乱码国产乱码精品精98午夜| 国产精品福利在线播放| 日韩激情一二三区| 91一区二区在线观看| 日韩欧美一级二级三级久久久| 91精品久久久久久蜜臀| 亚洲人123区| 亚洲精品综合在线| 国产夫妻精品视频| 3d成人动漫网站| 欧美丝袜自拍制服另类| 国产日产欧美一区二区三区| 丝袜美腿高跟呻吟高潮一区| 一本大道久久a久久综合| 久久久www免费人成精品| 久久久久久免费毛片精品| 婷婷激情综合网| 欧美日韩精品福利| 一区二区三区在线视频播放| 不卡在线观看av| 国产欧美综合色| 国产成人av一区二区三区在线观看| 成人黄页在线观看| 国产三级欧美三级日产三级99| 国产精品人人做人人爽人人添| 日本一区二区免费在线观看视频| 国产日本一区二区| 国产高清不卡一区| 99久久精品国产一区二区三区| 色乱码一区二区三区88| 欧美韩日一区二区三区四区| 国产乱妇无码大片在线观看| 91年精品国产| 亚洲乱码中文字幕综合| 在线亚洲高清视频| 日本视频一区二区三区| 日韩欧美三级在线| 国产精品99久久久久久久女警| 在线免费亚洲电影| 亚洲午夜激情网站| 欧美性大战xxxxx久久久| 欧美日韩午夜精品| 五月激情丁香一区二区三区| 制服丝袜一区二区三区| 国产一区二区福利| 成人欧美一区二区三区1314 | 亚洲蜜臀av乱码久久精品| 亚洲成人第一页| 91精品国产综合久久精品app | 成人三级在线视频| 亚洲欧美综合色| 国产精品亚洲第一| 国产精品人成在线观看免费| 精品视频999| 国产呦精品一区二区三区网站| 色菇凉天天综合网| 久久草av在线| 国产欧美日韩另类一区| 欧美主播一区二区三区美女| 麻豆精品国产91久久久久久| 色噜噜狠狠一区二区三区果冻| 欧美日韩免费在线视频| 精品粉嫩超白一线天av| 最好看的中文字幕久久| 美女一区二区久久| 国产精品久久久一区麻豆最新章节| 轻轻草成人在线| 欧美中文字幕久久| 精品一区二区三区香蕉蜜桃| 在线电影院国产精品| 韩日欧美一区二区三区| 欧美日韩精品欧美日韩精品一| 亚洲欧洲成人精品av97| 欧美精品免费视频| 首页国产欧美久久| 国产亚洲综合在线| 日韩视频在线一区二区| 欧美精品自拍偷拍| 国产精品一区二区男女羞羞无遮挡| 日韩欧美精品三级| 91免费版在线| 亚洲愉拍自拍另类高清精品| 日韩欧美一二三区| 欧洲视频一区二区| 成人app下载| 国产激情91久久精品导航| 日本视频中文字幕一区二区三区| 91精品国产综合久久久久久| 北岛玲一区二区三区四区|