Laravel5.1 模型 --一對一關系
阿新 • • 發佈:2017-09-15
規格 生成 table migrate guard factor create span 找不到
這篇文章主要記錄模型的一對一關系,關聯關系是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);
Laravel5.1 模型 --一對一關系