Laravel5.1 框架模型一對(duì)一關(guān)系實(shí)現(xiàn)與使用方法實(shí)例分析
本文實(shí)例講述了Laravel5.1 框架模型一對(duì)一關(guān)系實(shí)現(xiàn)與使用方法。分享給大家供大家參考,具體如下:
這篇文章主要記錄模型的一對(duì)一關(guān)系,關(guān)聯(lián)關(guān)系是Model的一種非常方便的功能。
1 實(shí)現(xiàn)一對(duì)一關(guān)系
1.1 準(zhǔn)備工作
首先我們需要?jiǎng)?chuàng)建兩張表和對(duì)應(yīng)的兩個(gè)模型,第一個(gè)模型是用戶表,第二個(gè)模型是賬號(hào)表。
這里 我們的邏輯是:一個(gè)用戶信息下只能有一個(gè)賬號(hào),一個(gè)賬號(hào)只能被一個(gè)用戶所擁有,這就是一對(duì)一關(guān)系。
1.1.1 用戶信息表
生成模型和遷移文件:
php artisan make:model UserInfo -m
編寫遷移文件(表規(guī)格):
  public function up()
  {
    Schema::create('user_infos', function (Blueprint $table) {
      $table->increments('id');
      $table->string('name');
      $table->string('phone_number');     // 手機(jī)號(hào)
      $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();
  }
生成數(shù)據(jù)并使用seeder填入數(shù)據(jù):
php artisan migrate:seeder
1.1.2 賬號(hào)表
編寫遷移文件(表規(guī)格):
  public function up()
  {
    Schema::create('accounts', function (Blueprint $table) {
      $table->increments('id');
      $table->string('user_name');    // 用戶名
      $table->integer('user_info_id');  // 關(guān)聯(lián)鍵
      $table->timestamps();
    });
  }
 
2 編寫關(guān)系
首先是賬號(hào)表,在模型下編寫以下代碼:
  public function user()
  {
    return $this->belongsTo(UserInfo::class, 'user_info_id', 'id');
  }
代碼解讀:belongsTo的第二個(gè)和第三個(gè)參數(shù)是完全可以省略的。如果省略了第二個(gè)和第三個(gè)參數(shù)的話 Laravel根據(jù)方法名自動(dòng)填充,會(huì)把第二個(gè)參數(shù)填充成 "user_id" 第三個(gè)參數(shù)填充 "id",但是我們現(xiàn)在必須這樣寫,因?yàn)槲易远x的外鍵是user_info_id 如果Laravel自動(dòng)填充的話是找不到這個(gè)外鍵的 所以我們要手動(dòng)的添加下。
belongsTo的第二個(gè)參數(shù)是 Account這個(gè)模型要用'user_info_id'外鍵去關(guān)聯(lián)UserInfo模型。
belongsTo的第三個(gè)參數(shù)是 Account這個(gè)模型要關(guān)聯(lián)UserInfo的主鍵名。
然后是用戶信息表:
  public function account()
  {
    return $this->hasOne(Account::class);
  }
代碼解讀:hasOne的第二個(gè)和第三個(gè)參數(shù)也是完全可以省略的。如果省略了第二個(gè)和第三個(gè)參數(shù)的話 Laravel會(huì)自動(dòng)填充,會(huì)把第二個(gè)參數(shù)填充成 "user_info_id" 第三個(gè)參數(shù)填充 "id"。
使用:
// $account = App\Account::find(1); // dd($account->user); $userInfo = App\UserInfo::find(1); dd($userInfo->account);
更多關(guān)于Laravel相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進(jìn)階教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家基于Laravel框架的PHP程序設(shè)計(jì)有所幫助。
上一篇:PHP字符串與數(shù)組處理函數(shù)用法小結(jié)
欄 目:PHP編程
下一篇:Laravel5.1 框架Request請(qǐng)求操作常見用法實(shí)例分析
本文標(biāo)題:Laravel5.1 框架模型一對(duì)一關(guān)系實(shí)現(xiàn)與使用方法實(shí)例分析
本文地址:http://www.jygsgssxh.com/a1/PHPbiancheng/10981.html
您可能感興趣的文章
- 01-11thinkphp框架類庫(kù)擴(kuò)展操作示例
 - 01-11關(guān)于Yii2框架跑腳本時(shí)內(nèi)存泄漏問題的分析與解決
 - 01-11php 實(shí)現(xiàn)簡(jiǎn)單的登錄功能示例【基于thinkPHP框架】
 - 01-11Laravel框架Blade模板簡(jiǎn)介及模板繼承用法分析
 - 01-11Laravel框架基礎(chǔ)語(yǔ)法與知識(shí)點(diǎn)整理【模板變量、輸出、include引入
 - 01-11Laravel框架Eloquent ORM刪除數(shù)據(jù)操作示例
 - 01-11Laravel框架Eloquent ORM修改數(shù)據(jù)操作示例
 - 01-11Laravel框架Eloquent ORM簡(jiǎn)介、模型建立及查詢數(shù)據(jù)操作詳解
 - 01-11laravel5.1框架下的批量賦值實(shí)現(xiàn)方法分析
 - 01-11laravel5.5框架的上傳圖片功能實(shí)例分析【僅傳到服務(wù)器端】
 


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
 - 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
 - 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
 - 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
 - 5c語(yǔ)言計(jì)算三角形面積代碼
 - 6什么是 WSH(腳本宿主)的詳細(xì)解釋
 - 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
 - 8正則表達(dá)式匹配各種特殊字符
 - 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
 - 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
 
本欄相關(guān)
- 04-02php本站才可以請(qǐng)求數(shù)據(jù) php本地?cái)?shù)據(jù)庫(kù)
 - 04-02關(guān)于txt數(shù)據(jù)庫(kù)php的信息
 - 04-02php打印請(qǐng)求數(shù)據(jù) php打印輸出結(jié)果
 - 04-02網(wǎng)頁(yè)里php操作數(shù)據(jù)庫(kù) php網(wǎng)頁(yè)例子
 - 04-02php插入數(shù)據(jù)庫(kù)為亂碼 php連接數(shù)據(jù)庫(kù)亂
 - 04-02php數(shù)據(jù)庫(kù)地址 phpstudy 數(shù)據(jù)庫(kù)
 - 04-02php數(shù)據(jù)庫(kù)數(shù)據(jù)相加 php數(shù)據(jù)庫(kù)添加數(shù)據(jù)
 - 04-02數(shù)據(jù)權(quán)限架構(gòu)思路php 數(shù)據(jù)權(quán)限設(shè)計(jì)方
 - 04-02php數(shù)據(jù)庫(kù)輸入變量 php里輸出數(shù)據(jù)庫(kù)數(shù)
 - 04-02php如何用導(dǎo)入數(shù)據(jù) php用來(lái)導(dǎo)入其他文
 
隨機(jī)閱讀
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
 - 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
 - 01-10C#中split用法實(shí)例總結(jié)
 - 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
 - 01-10delphi制作wav文件的方法
 - 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
 - 04-02jquery與jsp,用jquery
 - 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
 - 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
 - 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
 


