這篇文章給大家分享的是有關(guān)Laravel模型關(guān)聯(lián)關(guān)系最單純的“一對(duì)一”示例的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
成都創(chuàng)新互聯(lián)公司是專(zhuān)業(yè)的靈臺(tái)網(wǎng)站建設(shè)公司,靈臺(tái)接單;提供成都網(wǎng)站建設(shè)、成都網(wǎng)站制作,網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專(zhuān)業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行靈臺(tái)網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專(zhuān)業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專(zhuān)業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!引言
關(guān)系型數(shù)據(jù)庫(kù)提供了非常好用的數(shù)據(jù)關(guān)聯(lián)綁定模式,使用SQL語(yǔ)句可以方便地進(jìn)行關(guān)聯(lián)數(shù)據(jù)查詢(xún)和操作。
如果所有關(guān)聯(lián)關(guān)系放到數(shù)據(jù)庫(kù)層面操作,勢(shì)必非常不便。
所以,laravel模型提供了關(guān)聯(lián)關(guān)系,本文就來(lái)梳理梳理那些用法。
代碼時(shí)間
我們不要PPT似的念稿子,羅列出所有的關(guān)系模型,那樣不直觀也不是高效學(xué)習(xí)的方式。
還是從示例觸發(fā),看看關(guān)聯(lián)關(guān)系到底解決的是什么問(wèn)題,以及如何使用。
首先是數(shù)據(jù)庫(kù)的準(zhǔn)備,假設(shè)有如下兩個(gè)表的字段對(duì)應(yīng)關(guān)系:
使用命令行創(chuàng)建一個(gè)Profile模型,并同時(shí)創(chuàng)建遷移文件:
php artisan make:model Profile --migration
來(lái)看生成的app/Profile.php 文件的內(nèi)容:
namespace App;use Illuminate\Database\Eloquent\Model;class Profile extends Model {}
因?yàn)槭褂昧?strong>–migration 選項(xiàng),laravel自動(dòng)生成了database/migrations/2020_10_11_015236_create_profiles_table.php 文件,
用于生成對(duì)應(yīng)的數(shù)據(jù)庫(kù)profiles 表。
還是老規(guī)矩,先實(shí)現(xiàn)數(shù)據(jù)庫(kù)遷移使用的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(); });}
用于回滾的方法就不列出來(lái)了,僅僅是表的刪除。下面手動(dòng)執(zhí)行遷移指令:
php artisan migrate
輸出內(nèi)容如下:
Migrated: 2020_10_11_015236_create_profiles_table.php
關(guān)聯(lián)關(guān)系
一切準(zhǔn)備就緒,我們開(kāi)始使用關(guān)聯(lián)關(guān)系來(lái)處理數(shù)據(jù)的一致性。一個(gè)user對(duì)應(yīng)一個(gè)profile,所以這是一對(duì)一的關(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;
我們拆解開(kāi)做解釋。首先使用User::find($id) 返回的是一個(gè) User 模型對(duì)象的實(shí)例。
該實(shí)例有一個(gè)profile 方法,就是上面這段關(guān)系聲明。
調(diào)用profile 返回的是一個(gè) Profile 對(duì)象的實(shí)例,所以可以繼續(xù)調(diào)用Profile的屬性,也就是 telephone 的由來(lái)了。
需要特別注意的是,類(lèi)似下面的寫(xiě)法,返回結(jié)果是不同的:
$user = User::find($id); $user->profile; // 返回 Profile 對(duì)象 $user->profile(); // 返回 hasOne 關(guān)聯(lián)關(guān)系對(duì)象
大家在使用的時(shí)候,一定不要迷惑,要分清楚使用方法。
有了關(guān)聯(lián)查詢(xún),自然就有關(guān)聯(lián)更新,用法如下:
$profile = new Profile; $profile->telephone = '12345678'; $user = User::find(1); $user->profile()->save($profile);
有了關(guān)聯(lián)更新這種寫(xiě)操作,自然就有了關(guān)聯(lián)刪除,模型方法的調(diào)用而已:
$user = User::find($id); $user->profile()->delete();
由于是嚴(yán)格一對(duì)一的關(guān)系,也就是一個(gè)user只有一個(gè)profile,如果某個(gè)user被刪除了,
就會(huì)剩下一個(gè)孤零零的profile無(wú)所依附。
除了在程序上下文的一致性保證外,還可以使用數(shù)據(jù)庫(kù)的外鍵,在刪除user時(shí)將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)系最單純的“一對(duì)一”示例”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!