Laravel的工厂模型关系

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Laravel的工厂模型关系相关的知识,希望对你有一定的参考价值。

我有两个名为Users和Users_meta的表。两者都是分享一对一的关系。我想在播种的帮助下插入虚拟数据。我能做到这一点,唯一让我发疯的是,我无法在user_id作为外键的用户和users_meta表之间建立关系。我尝试了几种方法但是要么使用相同的user_id创建重复的entires,要么继续重复相同的user_id。

究竟我想要的是什么;在创建例如100条记录时,在第一次插入用户记录之后,它应该采用相同用户的user_ID,将其添加到users_meta表的user_id字段并重复插入直到100条假记录。

任何有关这方面的帮助将不胜感激

代码:UserFactory.php

$factory->define(AppUser::class, function (Faker $faker) {
static $password;

return [
    'username' => $faker->userName,
    'email' => $faker->unique()->safeEmail,
    'password' => $password ?: $password = bcrypt('secret'),
    'referral_code' => str_random(10),
    'referred_by_code' => str_random(10),
    'role'  => $faker->randomElement(['administrator', 'user', 'volunteer']),
    'remember_token' => str_random(10),
]; });

代码:UsersMetaFactory.php

$factory->define(AppUsersmeta::class, function (Faker $faker) {

return [
    'user_id'   =>  $faker->randomElement(AppUser::pluck('id')->toArray()),
    'first_name' => $faker->firstname,
    'last_name' => $faker->lastname,
    'gender' => $faker->randomElement(['male', 'female']),
    'date_of_birth' =>  $faker->dateTimeThisCentury->format('Y-m-d'),
    'address'   =>  $faker->address,
    'city'  =>  $faker->city,
    'state' =>  $faker->state,
    'zip_code'  =>  $faker->postcode,
    'country'   =>  $faker->country,
    'cell_phone'    =>  $faker->e164PhoneNumber,
    'bitcoin_address' => str_random(16),
    'monero_address'    =>  str_random(16),
    'security_question' =>  $faker->realText($maxNbChars = 20, $indexSize = 2),
    'security_answer'   =>  $faker->realText($maxNbChars = 40, $indexSize = 2),
    'is_founder'    =>  $faker->boolean($chanceOfGettingTrue = 50),
    'status'    =>  $faker->randomElement(['active', 'inactive']),
    'terms' =>  $faker->boolean
]; });

randomElement()方法为我提供了违反一对一关系主体的随机ID,我的应用程序崩溃了。我希望它应该从users表中获取id并将与user_id相同的id传递给users_meta表并继续生成虚假记录。

CreateUsersTable迁移类

public function up()
{
    Schema::create('users', function (Blueprint $table) {
        $table->increments('id');
        $table->string('username')->unique();
        $table->string('email')->unique();
        $table->string('password');
        $table->string('referral_code')->unique();
        $table->string('referred_by_code');
        $table->enum('role', ['administrator', 'user', 'volunteer'])->nullable();
        $table->rememberToken();
        $table->timestamps();
    });
}

CreateUsersMetaTable迁移类

public function up()
{
    Schema::create('users_meta', function (Blueprint $table) {
        $table->increments('id');
        $table->integer('user_id')->unsigned();
        $table->foreign('user_id')->references('id')->on('users');
        $table->string('first_name');
        $table->string('last_name');
        $table->enum('gender', ['male', 'female'])->nullable();
        $table->string('date_of_birth')->nullable();
        $table->string('address')->nullable();
        $table->string('city')->nullable();
        $table->string('state')->nullable();
        $table->string('zip_code')->nullable();
        $table->string('country');
        $table->string('cell_phone');
        $table->string('bitcoin_address')->nullable();
        $table->string('monero_address')->nullable();
        $table->string('security_question');
        $table->string('security_answer');
        $table->string('is_founder')->nullable();
        $table->enum('status', ['active', 'inactive'])->nullable();
        $table->string('terms');
        $table->timestamps();
    });
}

public function down()
{
    Schema::dropIfExists('users_meta');
    Schema::enableForeignKeyConstraints();
}
答案

你应该删除这一行:

'user_id' => $faker->randomElement(AppUser::pluck('id')->toArray()),

并在创建新模型时使用关系。这是一个修改过的例子from the docs

factory(AppUser::class, 50)->create()->each(function ($u) {
    $u->usersmeta()->save(factory(AppUsersmeta::class)->make());
});

以上是关于Laravel的工厂模型关系的主要内容,如果未能解决你的问题,请参考以下文章

在 laravel 5.2 中使用工厂关系违反完整性约束

Laravel - 播种关系

当模型有构造函数时,Laravel 工厂失败

是否可以在 Laravel 项目中使用自己工厂中的模型?

Laravel 8 工厂的多重关系

Laravel 8 - 当工厂中的自引用关系时,该过程已用信号“11”发出信号