欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

使用Laravel怎么實現(xiàn)模型關聯(lián)-創(chuàng)新互聯(lián)

本篇文章給大家分享的是有關使用Laravel怎么實現(xiàn)模型關聯(lián),小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

創(chuàng)新互聯(lián)建站主營華龍網(wǎng)站建設的網(wǎng)絡公司,主營網(wǎng)站建設方案,app軟件開發(fā),華龍h5重慶小程序開發(fā)搭建,華龍網(wǎng)站營銷推廣歡迎華龍等地區(qū)企業(yè)咨詢

一對一


一對一關聯(lián)是目前存在的最基本的關聯(lián)。這種關聯(lián)意味著 A 模型只能鏈接到 B 模型,相反也是如此。舉個例子,一個 User 模型和一個 Passport 模型會成為一對一的關聯(liá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 。

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


在 Passport 模型中,我們需要定義逆向的關聯(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 中定義的下一個關聯(lián)是一對多關聯(lián)。 這種類型的關聯(lián)意味著一個類型A的模型可以鏈接到多個類型B的模型。但是類型B的模型只屬于一個類型A的模型。

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

在代碼中是這樣寫的:

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

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

我們現(xiàn)在要做的就是讓 Invoice 模型知道它屬于 User 模型。 讓我們定義一對多關聯(lián)的反向?qū)P聯(lián)吧。

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

多對多


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

例如,Invoice  模型和 Product  模型之間的關聯(liá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);
  }
}

你可以像這樣定義這種關聯(lián)的反向關系:

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

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

遠程關聯(lián)


遠程一對一


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

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

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 方法的第一個參數(shù)是希望訪問模型的名稱。 第二個參數(shù)是中間模型的名稱。

遠程一對多


「has many through」 關聯(lián)相當于 「has one through」 關聯(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)品的歷史記錄條目。

查詢關聯(lián)


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

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

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

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

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

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

查詢多對多關聯(lián)的工作方式與其他關聯(lián)完全相同。 此外,多對多關聯(lián)有一個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 的工作方式與其他關聯(lián)完全相同。

添加約束


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

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

檢查關聯(liá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怎么實現(xiàn)模型關聯(lián),小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

新聞名稱:使用Laravel怎么實現(xiàn)模型關聯(lián)-創(chuàng)新互聯(lián)
網(wǎng)址分享:http://aaarwkj.com/article18/phpgp.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供手機網(wǎng)站建設、品牌網(wǎng)站建設、App開發(fā)、外貿(mào)建站外貿(mào)網(wǎng)站建設、面包屑導航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化
亚洲一二三区精品与老人| 人妻av天堂综合一区| 亚洲熟妇亚洲熟妇亚洲熟妇 | 免费看的日韩av毛片| 国产av毛片一区二区| 夫妻性生活视频在线免费看| 天天天干夜夜添狠操美女| 欧美一区二区三区日韩色| 精品中文字幕欧美区一区| 另类国产人妖免费视频网站大全| 国产精品亚洲国产精品| 原创国产av剧情精品| 可以免费看的日韩黄色| 韩国久久久久三级成人| 成人性生活三级黄色片| 国产精品深夜在线观看| 成熟性性生活免费视频| 日韩成人手机视频在线观看| 欧美国产日韩在线一区二区三区| 婷婷色悠悠,色悠悠激情啪啪| 久久97精品人人做人人爽| 国产日韩欧美在线精品| 亚洲成人精品免费观看| 视频一区二区中文字幕日韩| 亚洲黄色成人免费观看| 开心激情欧美一区二区| 欧美熟妇在线视频你懂的| 中国美女下面毛茸茸视频| 麻豆人妻少妇精品毛片| 日韩精品在线播放观看| 亚洲日本精品免费在线观看| 一本色道久久88综合日韩| 国产一级成人免费视频| 我想看日韩一级黄色片| 国产剧情av在线播放| 麻豆剧传媒国产精选av| 精品国产50部农村老熟女av| 野花日本免费高清完整| 国产精品成人一区二区三| 成人一区二区三区播放| 久久偷拍一区二区三区|