“General error: 1005 Can't create table” Using Laravel Schema Build and Foreign Keys

后端 未结 11 1063
予麋鹿
予麋鹿 2020-12-03 07:02

Essentially, I am having the same issue as this guy, minus the table prefix. Because I have no table prefix, his fix does not work. http://forums.laravel.com/viewtopic.php?i

相关标签:
11条回答
  • 2020-12-03 07:21

    I ran into this issue too.

    The solution I found is that the tables that contain the id that is being used a foreign id needs to be created before another table can reference it. Basically, you are creating a table and telling MySQL to reference another table's primary key but that table doesn't exist yet.

    In your example, the author and lesson tables need to be created first.

    The order in which the tables are created is dependent on artisan and the order you created your migration files.

    My opinion would be to empty out your database of all the tables and change the timestamps in the migration file names (or delete them and recreate them in the correct order) so that your author and lesson tables are created before your tutorials table.

    0 讨论(0)
  • 2020-12-03 07:26

    Laravel5, MySQL55, CentOS65

    in my case the errors were same as this.

    Error: [Illuminate\Database\QueryException]
    SQLSTATE[HY000]: General error: 1005 Can't create table 'nabsh.#sql-5b0_e' (errno: 121) (SQL: alter table usermeta add constraint usermeta_uid_foreign foreign key (uid) ref erences users (id) on delete cascade).

    I found a good tip in this problem's approved answer: ERROR: Error 1005: Can't create table (errno: 121)

    Tip: You will get this message if you're trying to add a constraint with a name that's already used somewhere else.

    in my case this error means the constraint which has been tried to add is already exists somewhere (but i couldn't see them anywhere).

    I copied the output error query and execute it within sequel pro, then hopefully I saw the same error again. as the tip says I changed the constraint name to something else then it affected with no error so there's a problem with constraint name builder in laravel5 + MySQL55 + CentOS65.

    Solution: try to rename constraints by sending the second parameter at foreign method in table schema.

    Schema::table('tutorials', function($table)
    {
        $table->foreign('author')->references('id')->on('users');
        $table->foreign('lesson')->references('id')->on('lessons');
    });
    

    to ->

    Schema::table('tutorials', function($table)
    {
        $table->foreign('author', 'fk_tutorials_author')->references('id')->on('users');
        $table->foreign('lesson', 'fk_tutorials_lesson')->references('id')->on('lessons');
    });
    

    i hope it helps. it works in my case

    0 讨论(0)
  • 2020-12-03 07:27

    A Summary of the answers already listed, plus mine:

    1. Foreign Keys generally require InnoDb, so set your default engine, or explicitly specify

      $table->engine = 'InnoDB';
      
    2. Foreign keys require the referenced table to exist. Make sure the referenced table is created in an earlier migration, prior to creating the key. Consider creating the keys in a separate migration to be sure.

    3. Foreign Keys require the data type to be congruent. Check whether the referenced field is the same type, whether its signed or unsigned, whether it's length is the same (or less).

    4. If you are switching between hand-coding migrations, and using generators, make sure you check the id type you are using. Artisan uses increments() by default but Jeffrey Way appears to prefer integer('id', true).

    0 讨论(0)
  • 2020-12-03 07:27

    Easiest way is to disable foreign key checks:

    DB::statement('set foreign_key_checks=0');
    
    Schema::table( ... );
    
    DB::statement('set foreign_key_checks=1');
    
    0 讨论(0)
  • 2020-12-03 07:30

    This happened to me in Yii Framework 1.x migrations too. Turned out that similarily to the Laravel solutions above it may be caused by a

    • wrong spelled (or not yet existing) table name
    • wrong spelled (or not yet existing) column name
    • duplicate foreign key name in the same database being used in different tables
    0 讨论(0)
提交回复
热议问题