91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Laravel模型關聯關系最單純的“一對一”示例

發布時間:2021-03-10 14:24:26 來源:億速云 閱讀:123 作者:小新 欄目:編程語言

這篇文章給大家分享的是有關Laravel模型關聯關系最單純的“一對一”示例的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

引言

關系型數據庫提供了非常好用的數據關聯綁定模式,使用SQL語句可以方便地進行關聯數據查詢和操作。

如果所有關聯關系放到數據庫層面操作,勢必非常不便。

所以,laravel模型提供了關聯關系,本文就來梳理梳理那些用法。

代碼時間

我們不要PPT似的念稿子,羅列出所有的關系模型,那樣不直觀也不是高效學習的方式。

還是從示例觸發,看看關聯關系到底解決的是什么問題,以及如何使用。

首先是數據庫的準備,假設有如下兩個表的字段對應關系:

Laravel模型關聯關系最單純的“一對一”示例

使用命令行創建一個Profile模型,并同時創建遷移文件:

php artisan make:model Profile --migration

來看生成的 app/Profile.php 文件的內容:

namespace App;use Illuminate\Database\Eloquent\Model;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('App\Profile');
    }}

一旦定義了上述方法,就可以這樣鏈式調用了:

$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模型關聯關系最單純的“一對一”示例”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

定远县| 高州市| 新宁县| 江源县| 罗定市| 如皋市| 特克斯县| 定结县| 罗田县| 察哈| 公主岭市| 若尔盖县| 拜泉县| 乐昌市| 绥中县| 连州市| 大方县| 谢通门县| 濉溪县| 渝北区| 兴仁县| 鹤峰县| 会同县| 鹤庆县| 罗定市| 连江县| 武夷山市| 高安市| 文安县| 门源| 手游| 康定县| 永顺县| 扎兰屯市| 内丘县| 仁怀市| 上栗县| 同德县| 滨海县| 仁化县| 大姚县|