真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Laravel模型關(guān)聯(lián)關(guān)系最單純的“一對(duì)一”示例-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(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)系:

Laravel模型關(guān)聯(lián)關(guān)系最單純的“一對(duì)一”示例

使用命令行創(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ò),可以把它分享出去讓更多的人看到吧!


網(wǎng)頁(yè)標(biāo)題:Laravel模型關(guān)聯(lián)關(guān)系最單純的“一對(duì)一”示例-創(chuàng)新互聯(lián)
瀏覽地址:http://weahome.cn/article/hpcgi.html

其他資訊

在線(xiàn)咨詢(xún)

微信咨詢(xún)

電話(huà)咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部