下面由laravel教程欄目給大家介紹Laravel模型關聯關系最單純的“一對一”! ,希望對需要的朋友有所幫助!
引言
關系型數據庫提供了非常好用的數據關聯綁定模式,使用sql語句可以方便地進行關聯數據查詢和操作。
如果所有關聯關系放到數據庫層面操作,勢必非常不便。
所以,laravel模型提供了關聯關系,本文就來梳理梳理那些用法。
代碼時間
我們不要PPT似的念稿子,羅列出所有的關系模型,那樣不直觀也不是高效學習的方式。
還是從示例觸發,看看關聯關系到底解決的是什么問題,以及如何使用。
首先是數據庫的準備,假設有如下兩個表的字段對應關系:
使用命令行創建一個Profile模型,并同時創建遷移文件:
php artisan make:model Profile --migration
來看生成的 app/Profile.php 文件的內容:
namespace App;use IlluminatedatabaseEloquentModel;class Profile extends Model {}
因為使用了 –migration 選項,laravel自動生成了 database/migrations/2020_10_11_015236_create_profiles_table.php 文件,
用于生成對應的數據庫 profiles 表。
還是老規矩,先實現數據庫遷移使用的 up 方法:
public function up(){ Schema::create('profiles', function(Blueprint $table) { $table->increments('id'); $table->integer('user_id')->unsigned(); $table->foreign('user_id')->references('id')->on('users'); $table->string('url'); $table->string('telephone'); $table->timestamps(); });}
用于回滾的方法就不列出來了,僅僅是表的刪除。下面手動執行遷移指令:
php artisan migrate
輸出內容如下:
Migrated: 2020_10_11_015236_create_profiles_table.php
關聯關系
一切準備就緒,我們開始使用關聯關系來處理數據的一致性。一個user對應一個profile,所以這是一對一的關系,
在User模型里添加如下聲明:
class User extends Model { public function profile() { return $this->hasOne('AppProfile'); }}
一旦定義了上述方法,就可以這樣鏈式調用了:
$user = User::find(1)->profile->telephone;
我們拆解開做解釋。首先使用 User::find($id) 返回的是一個 User 模型對象的實例。
該實例有一個 profile 方法,就是上面這段關系聲明。
調用 profile 返回的是一個 Profile 對象的實例,所以可以繼續調用Profile的屬性,也就是 telephone 的由來了。
需要特別注意的是,類似下面的寫法,返回結果是不同的:
$user?=?User::find($id); $user->profile;?//?返回?Profile?對象 $user->profile();?//?返回?hasOne?關聯關系對象
大家在使用的時候,一定不要迷惑,要分清楚使用方法。
有了關聯查詢,自然就有關聯更新,用法如下:
$profile?=?new?Profile; $profile->telephone?=?'12345678'; $user?=?User::find(1); $user->profile()->save($profile);
有了關聯更新這種寫操作,自然就有了關聯刪除,模型方法的調用而已:
$user?=?User::find($id); $user->profile()->delete();
由于是嚴格一對一的關系,也就是一個user只有一個profile,如果某個user被刪除了,
就會剩下一個孤零零的profile無所依附。
除了在程序上下文的一致性保證外,還可以使用數據庫的外鍵,在刪除user時將profile關聯刪除。那么只要修改遷移文件,
并添加如下內容:
$table->integer('user_id')->unsigned(); $table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');
寫在最后
本文介紹了laravel模型關聯的最簡單的“一對一”,我們從程序角度和數據庫角度講解了
如何在刪除資源時的一致性刪除。更復雜的關系,在編程層面是有意義的,我們下一章介紹更多的關聯關系。? ? ? ? ? ? ? ? ? ? ? ??? ? ? ? ? ?