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

 更新時間:2020-01-24 13:00:38   作者:佚名   我要評論(0)

本文實例講述了Laravel5.1 框架模型一對一關系實現與使用方法。分享給大家供大家參考,具體如下:
這篇文章主要記錄模型的一對一關系,關聯關系是Model的一種非常方

本文實例講述了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程序設計有所幫助。

您可能感興趣的文章:

  • Laravel 關聯模型-關聯新增和關聯更新的方法
  • Laravel關聯模型中過濾結果為空的結果集(has和with區別)
  • laravel學習教程之關聯模型
  • Laravel5.1 框架模型多態關聯用法實例分析
  • Laravel等框架模型關聯的可用性淺析
  • Laravel Eloquent分表方法并使用模型關聯的實現
  • Laravel 模型關聯基礎教程詳解
  • Laravel5.1 框架模型遠層一對多關系實例分析
  • Laravel5.1 框架模型查詢作用域定義與用法實例分析
  • Laravel5.1 框架模型創建與使用方法實例分析
  • Laravel5.1 框架關聯模型之后操作實例分析

相關文章

最新評論

老快3投注技巧 在线股票查询 正规配资平台 湖北体彩11选5投注表 广西快十开奖走势图 3d过滤器 2019年大牛股正虹科技 青海快三今天开奖号 股票涨跌由庄家决定吗 山西快乐十分走势山图表分析 山东快乐扑克在线开奖 昨晚快乐双彩开奖结果 广东快乐10分助手平 最新双色球基本走势图50期 双面盘怎么看走势图 三肖选一肖中特 股票下跌可以买入吗