您好,登錄后才能下訂單哦!
這篇文章主要介紹了如何使用Laravel實現模型關聯的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇如何使用Laravel實現模型關聯文章都會有所收獲,下面我們一起來看看吧。
一對一
一對一關聯是目前存在的最基本的關聯。這種關聯意味著 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實現模型關聯”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。