1. 程式人生 > 程式設計 >Laravel5.1 框架模型一對一關係實現與使用方法例項分析

Laravel5.1 框架模型一對一關係實現與使用方法例項分析

本文例項講述了Laravel5.1 框架模型一對一關係實現與使用方法。分享給大家供大家參考,具體如下:

這篇文章主要記錄模型的一對一關係,關聯關係是Model的一種非常方便的功能。

1 實現一對一關係

1.1 準備工作

首先我們需要建立兩張表和對應的兩個模型,第一個模型是使用者表,第二個模型是賬號表。

這裡 我們的邏輯是:一個使用者資訊下只能有一個賬號,一個賬號只能被一個使用者所擁有,這就是一對一關係。

1.1.1 使用者資訊表

生成模型和遷移檔案:

php artisan make:model UserInfo -m

編寫遷移檔案(表規格):

  public function up()
  {
    Schema::create('user_infos',function (Blueprint $table) {
      $table->increments('id');
      $table->string('name');
      $table->string('phone_number');     // 手機號
      $table->timestamps();
    });
  }

編寫模型工廠:

// user_info
$factory->define(App\UserInfo::class,function (Faker\Generator $faker) {
  return [
    'name' => $faker->name,'phone_number' => $faker->phoneNumber,];
});

使用seeder:

php artisan make:seeder UserInfoSeeder

  public function run()
  {
    factory(\App\UserInfo::class,10)->create();
  }
  public function run()
  {
    Model::unguard();
    $this->call('UserInfoSeeder');
    Model::reguard();
  }

生成資料並使用seeder填入資料:

php artisan migrate:seeder 

1.1.2 賬號表

編寫遷移檔案(表規格):

  public function up()
  {
    Schema::create('accounts',function (Blueprint $table) {
      $table->increments('id');
      $table->string('user_name');    // 使用者名稱
      $table->integer('user_info_id');  // 關聯鍵
      $table->timestamps();
    });
  }
 

2 編寫關係

首先是賬號表,在模型下編寫以下程式碼:

  public function user()
  {
    return $this->belongsTo(UserInfo::class,'user_info_id','id');
  }

程式碼解讀:belongsTo的第二個和第三個引數是完全可以省略的。如果省略了第二個和第三個引數的話 Laravel根據方法名自動填充,會把第二個引數填充成 "user_id" 第三個引數填充 "id",但是我們現在必須這樣寫,因為我自定義的外來鍵是user_info_id 如果Laravel自動填充的話是找不到這個外來鍵的 所以我們要手動的新增下。

belongsTo的第二個引數是 Account這個模型要用'user_info_id'外來鍵去關聯UserInfo模型。

belongsTo的第三個引數是 Account這個模型要關聯UserInfo的主鍵名。

然後是使用者資訊表:

  public function account()
  {
    return $this->hasOne(Account::class);
  }

程式碼解讀:hasOne的第二個和第三個引數也是完全可以省略的。如果省略了第二個和第三個引數的話 Laravel會自動填充,會把第二個引數填充成 "user_info_id" 第三個引數填充 "id"。

使用:

//  $account = App\Account::find(1);
//  dd($account->user);
  $userInfo = App\UserInfo::find(1);
  dd($userInfo->account);

更多關於Laravel相關內容感興趣的讀者可檢視本站專題:《Laravel框架入門與進階教程》、《php優秀開發框架總結》、《php面向物件程式設計入門教程》、《php+mysql資料庫操作入門教程》及《php常見資料庫操作技巧彙總》

希望本文所述對大家基於Laravel框架的PHP程式設計有所幫助。