您好,登錄后才能下訂單哦!
使用Laravel5.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
編寫遷移文件(表規格):
public function up() { Schema::create('accounts', function (Blueprint $table) { $table->increments('id'); $table->string('user_name'); // 用戶名 $table->integer('user_info_id'); // 關聯鍵 $table->timestamps(); }); }
首先是賬號表,在模型下編寫以下代碼:
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);
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。