Laravel: ошибка при использовании фабрики для внешнего ключа - PullRequest
1 голос
/ 31 марта 2020

У меня есть следующая миграция (для сводной таблицы):

        Schema::create('category_news', function (Blueprint $table) {
            $table->id();
            $table->timestamps();
            $table->unsignedBigInteger('category_id');
            $table->unsignedBigInteger('news_id');

            $table->unique(['category_id', 'news_id']);

            $table->foreign('news_id')->references('id')->on('news')->onDelete('cascade');
            $table->foreign('category_id')->references('id')->on('categories')->onDelete('cascade');
        });

Я хочу заполнить эту таблицу некоторыми фиктивными данными - для этого я создал следующую фабрику:

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

  return [
    'category_id' => $faker->numberBetween($min = 1, $max = 35),
    'news_id' => $faker->numberBetween($min = 1, $max = 150)
  ];

});

Однако, когда я запускаю следующую команду: php artisan migrate:fresh --seed, я получаю следующую ошибку:

 Illuminate\Database\QueryException

  SQLSTATE[23000]: Integrity constraint violation: 1452 Cannot add or update a child row: a foreign key constraint fails (`startup-reporter`.`category_news`, CONSTRAINT `category_news_news_id_foreign` FOREIGN KEY (`news_id`) REFERENCES `news` (`id`) ON DELETE CASCADE) (SQL: insert into `category_news` (`category_id`, `news_id`, `updated_at`, `created_at`) values (16, 13, 2020-03-31 10:44:04, 2020-03-31 10:44:04))

  at C:\laragon\www\startup-reporter\vendor\laravel\framework\src\Illuminate\Database\Connection.php:669
    665|         // If an exception occurs when attempting to run a query, we'll format the error
    666|         // message to include the bindings with SQL, which will make this exception a
    667|         // lot more helpful to the developer instead of just the database's errors.
    668|         catch (Exception $e) {
  > 669|             throw new QueryException(
    670|                 $query, $this->prepareBindings($bindings), $e
    671|             );
    672|         }
    673|

  1   C:\laragon\www\startup-reporter\vendor\laravel\framework\src\Illuminate\Database\Connection.php:463
      PDOException::("SQLSTATE[23000]: Integrity constraint violation: 1452 Cannot add or update a child row: a foreign key constraint fails (`startup-reporter`.`category_news`, CONSTRAINT `category_news_news_id_foreign` FOREIGN KEY (`news_id`) REFERENCES `news` (`id`) ON DELETE CASCADE)")

  2   C:\laragon\www\startup-reporter\vendor\laravel\framework\src\Illuminate\Database\Connection.php:463
      PDOStatement::execute()

Любая идея, почему и что мне нужно сделать, чтобы это исправить?

Спасибо.

Ответы [ 2 ]

0 голосов
/ 31 марта 2020

вы пытаетесь добавить новую запись category_news с category_id = 16, в то время как у вас нет категории с id = 16, поэтому ограничение выдает ошибку ... вы не можете использовать random int, чтобы назначить ее ссылки на ваши внешние ключи ... вы можете просто сделать что-то вроде этого:

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

  return [
    'category_id' => Category::all()->random()->id,
    'news_id' => News::all()->random()->id,
  ];
});

я нашел здесь вот что: { ссылка }

0 голосов
/ 31 марта 2020

Я понял это - мне пришлось изменить порядок файлов DatabaseSeeder.php, чтобы вызвать файл NewsTableSeeder до того, как я вызвал файл CategoryNewsTableSeeder.

...