Не удается обрезать таблицу перед раздачей

Я хочу обрезать свою пользовательскую таблицу перед seed. Я делаю так:

База данныхSeeder.php:

 <?php

 use Illuminate\Database\Seeder;
 use Illuminate\Support\Facades\DB;

 class DatabaseSeeder extends Seeder
 {
     public function run()
     {
         App\User::truncate();

         factory(App\User::class,1)->create();
     }
 }

Затем запустите php artisan db:seed и получите ошибку:

In Connection.php line 664:

  SQLSTATE[42000]: Syntax error or access violation: 1701 Cannot truncate a table referenced in a foreign key constra
  int (`mr_musicer`.`dislikes`, CONSTRAINT `dislikes_user_id_foreign` FOREIGN KEY (`user_id`) REFERENCES `mr_musicer`
  .`users` (`id`)) (SQL: truncate `users`)


In Connection.php line 458:

  SQLSTATE[42000]: Syntax error or access violation: 1701 Cannot truncate a table referenced in a foreign key constra
  int (`mr_musicer`.`dislikes`, CONSTRAINT `dislikes_user_id_foreign` FOREIGN KEY (`user_id`) REFERENCES `mr_musicer`
  .`users` (`id`))

Теперь я хочу узнать, почему я не могу обрезать свою пользовательскую таблицу!

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
4
0
4 010
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

У вас есть ссылки на ваших пользователей в какой-то другой таблице. Вы должны добавить ->onDelete('cascade') в столбец таблицы не нравится, который ссылается на идентификатор пользователя, или сначала удалить все не нравится вручную.

$table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');

я использовал cascade во всех таких таблицах: $table->foreign('user_id')->references('id')->on('users')->o‌​nDelete('cascade')->‌​onUpdate('cascade');

Omid Reza 01.04.2019 21:51
Ответ принят как подходящий

Существует проблема с внешним ключом, и таблица пытается напомнить вам об этом. Если вы все равно хотите обрезать таблицу.

    Schema::disableForeignKeyConstraints();

    // ... Some Truncate Query

    Schema::enableForeignKeyConstraints();

Не забудьте использовать: use Illuminate\Support\Facades\Schema;

Самый простой способ обрезать данные перед раздачей

Просто добавьте эту единственную строку в начале вашего метода запуска.

DB::table('users')->truncate();

Полный синтаксис с методом run

namespace Database\Seeders;

use Illuminate\Database\Seeder;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Hash;

class AdminSeeder extends Seeder
{
    /**
     * Run the database seeds.
     *
     * @return void
     */
    public function run()
    {
        DB::table('users')->truncate();
        DB::table('users')->insert([
            'name' => 'Admin',
            'email' => '[email protected]',
            'is_admin' => 1,
            'password' => Hash::make('password'),
        ]);
    }
}

Другие вопросы по теме