本文實例講述了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中實現ORM模型使用第二個數據庫設置
- 使用laravel的Eloquent模型如何獲取數據庫的指定列
- Laravel5.1 框架關聯模型之后操作實例分析
- Laravel5.1 框架模型多態關聯用法實例分析
- Laravel5.1 框架模型遠層一對多關系實例分析
- Laravel5.1 框架模型查詢作用域定義與用法實例分析
- Laravel5.1 框架模型軟刪除操作實例分析
- Laravel5.1 框架模型創建與使用方法實例分析
- Laravel框架視圖和模型操作方法分析
- Laravel 5框架學習之模型、控制器、視圖基礎流程
- laravel學習教程之關聯模型
- laravel框架模型和數據庫基礎操作實例詳解