本文實(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)秀開(kāi)發(fā)框架總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家基于Laravel框架的PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- 在laravel中實(shí)現(xiàn)ORM模型使用第二個(gè)數(shù)據(jù)庫(kù)設(shè)置
- 使用laravel的Eloquent模型如何獲取數(shù)據(jù)庫(kù)的指定列
- Laravel5.1 框架關(guān)聯(lián)模型之后操作實(shí)例分析
- Laravel5.1 框架模型多態(tài)關(guān)聯(lián)用法實(shí)例分析
- Laravel5.1 框架模型遠(yuǎn)層一對(duì)多關(guān)系實(shí)例分析
- Laravel5.1 框架模型查詢作用域定義與用法實(shí)例分析
- Laravel5.1 框架模型軟刪除操作實(shí)例分析
- Laravel5.1 框架模型創(chuàng)建與使用方法實(shí)例分析
- Laravel框架視圖和模型操作方法分析
- Laravel 5框架學(xué)習(xí)之模型、控制器、視圖基礎(chǔ)流程
- laravel學(xué)習(xí)教程之關(guān)聯(lián)模型
- laravel框架模型和數(shù)據(jù)庫(kù)基礎(chǔ)操作實(shí)例詳解