這篇文章給大家分享的是有關(guān)Laravel模型關(guān)聯(lián)關(guān)系最單純的“一對一”示例的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)服務(wù)項目包括葉集網(wǎng)站建設(shè)、葉集網(wǎng)站制作、葉集網(wǎng)頁制作以及葉集網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,葉集網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到葉集省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
引言
關(guān)系型數(shù)據(jù)庫提供了非常好用的數(shù)據(jù)關(guān)聯(lián)綁定模式,使用SQL語句可以方便地進行關(guān)聯(lián)數(shù)據(jù)查詢和操作。
如果所有關(guān)聯(lián)關(guān)系放到數(shù)據(jù)庫層面操作,勢必非常不便。
所以,laravel模型提供了關(guān)聯(lián)關(guān)系,本文就來梳理梳理那些用法。
代碼時間
我們不要PPT似的念稿子,羅列出所有的關(guān)系模型,那樣不直觀也不是高效學(xué)習(xí)的方式。
還是從示例觸發(fā),看看關(guān)聯(lián)關(guān)系到底解決的是什么問題,以及如何使用。
首先是數(shù)據(jù)庫的準(zhǔn)備,假設(shè)有如下兩個表的字段對應(yīng)關(guān)系:
使用命令行創(chuàng)建一個Profile模型,并同時創(chuàng)建遷移文件:
php artisan make:model Profile --migration
來看生成的 app/Profile.php文件的內(nèi)容:
namespace App;use Illuminate\Database\Eloquent\Model;class Profile extends Model {}
因為使用了 –migration選項,laravel自動生成了 database/migrations/2020_10_11_015236_create_profiles_table.php文件,
用于生成對應(yīng)的數(shù)據(jù)庫 profiles表。
還是老規(guī)矩,先實現(xiàn)數(shù)據(jù)庫遷移使用的 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(); });}
用于回滾的方法就不列出來了,僅僅是表的刪除。下面手動執(zhí)行遷移指令:
php artisan migrate
輸出內(nèi)容如下:
Migrated: 2020_10_11_015236_create_profiles_table.php
關(guān)聯(lián)關(guān)系
一切準(zhǔn)備就緒,我們開始使用關(guān)聯(lián)關(guān)系來處理數(shù)據(jù)的一致性。一個user對應(yīng)一個profile,所以這是一對一的關(guān)系,
在User模型里添加如下聲明:
class User extends Model { public function profile() { return $this->hasOne('App\Profile'); }}
一旦定義了上述方法,就可以這樣鏈?zhǔn)秸{(diào)用了:
$user = User::find(1)->profile->telephone;
我們拆解開做解釋。首先使用 User::find($id)返回的是一個 User 模型對象的實例。
該實例有一個 profile方法,就是上面這段關(guān)系聲明。
調(diào)用 profile返回的是一個 Profile 對象的實例,所以可以繼續(xù)調(diào)用Profile的屬性,也就是 telephone 的由來了。
需要特別注意的是,類似下面的寫法,返回結(jié)果是不同的:
$user = User::find($id); $user->profile; // 返回 Profile 對象 $user->profile(); // 返回 hasOne 關(guān)聯(lián)關(guān)系對象
大家在使用的時候,一定不要迷惑,要分清楚使用方法。
有了關(guān)聯(lián)查詢,自然就有關(guān)聯(lián)更新,用法如下:
$profile = new Profile; $profile->telephone = '12345678'; $user = User::find(1); $user->profile()->save($profile);
有了關(guān)聯(lián)更新這種寫操作,自然就有了關(guān)聯(lián)刪除,模型方法的調(diào)用而已:
$user = User::find($id); $user->profile()->delete();
由于是嚴(yán)格一對一的關(guān)系,也就是一個user只有一個profile,如果某個user被刪除了,
就會剩下一個孤零零的profile無所依附。
除了在程序上下文的一致性保證外,還可以使用數(shù)據(jù)庫的外鍵,在刪除user時將profile關(guān)聯(lián)刪除。那么只要修改遷移文件,
并添加如下內(nèi)容:
$table->integer('user_id')->unsigned(); $table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');
感謝各位的閱讀!關(guān)于“Laravel模型關(guān)聯(lián)關(guān)系最單純的“一對一”示例”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!