Laravel5.1 框架模型一對一關系實現(xiàn)與使用方法實例分析
本文實例講述了Laravel5.1 框架模型一對一關系實現(xiàn)與使用方法。分享給大家供大家參考,具體如下:
這篇文章主要記錄模型的一對一關系,關聯(lián)關系是Model的一種非常方便的功能。
1 實現(xiàn)一對一關系
1.1 準備工作
首先我們需要創(chuàng)建兩張表和對應的兩個模型,第一個模型是用戶表,第二個模型是賬號表。
這里 我們的邏輯是:一個用戶信息下只能有一個賬號,一個賬號只能被一個用戶所擁有,這就是一對一關系。
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'); // 手機號
$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 賬號表
編寫遷移文件(表規(guī)格):
public function up()
{
Schema::create('accounts', function (Blueprint $table) {
$table->increments('id');
$table->string('user_name'); // 用戶名
$table->integer('user_info_id'); // 關聯(lián)鍵
$table->timestamps();
});
}
2 編寫關系
首先是賬號表,在模型下編寫以下代碼:
public function user()
{
return $this->belongsTo(UserInfo::class, 'user_info_id', 'id');
}
代碼解讀:belongsTo的第二個和第三個參數(shù)是完全可以省略的。如果省略了第二個和第三個參數(shù)的話 Laravel根據(jù)方法名自動填充,會把第二個參數(shù)填充成 "user_id" 第三個參數(shù)填充 "id",但是我們現(xiàn)在必須這樣寫,因為我自定義的外鍵是user_info_id 如果Laravel自動填充的話是找不到這個外鍵的 所以我們要手動的添加下。
belongsTo的第二個參數(shù)是 Account這個模型要用'user_info_id'外鍵去關聯(lián)UserInfo模型。
belongsTo的第三個參數(shù)是 Account這個模型要關聯(lián)UserInfo的主鍵名。
然后是用戶信息表:
public function account()
{
return $this->hasOne(Account::class);
}
代碼解讀:hasOne的第二個和第三個參數(shù)也是完全可以省略的。如果省略了第二個和第三個參數(shù)的話 Laravel會自動填充,會把第二個參數(shù)填充成 "user_info_id" 第三個參數(shù)填充 "id"。
使用:
// $account = App\Account::find(1); // dd($account->user); $userInfo = App\UserInfo::find(1); dd($userInfo->account);
更多關于Laravel相關內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進階教程》、《php優(yōu)秀開發(fā)框架總結》、《php面向對象程序設計入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家基于Laravel框架的PHP程序設計有所幫助。
相關文章
phpexcel導入excel數(shù)據(jù)使用方法實例
phpexcel導入excel數(shù)據(jù)使用方法,大家參考使用吧2013-12-12

