So I am trying to add a primary key to one of the tables in my database. Right now it has a primary key like this:
PRIMARY KEY (user_id, round_number)
Where user_id is a foreign key.
I am trying to change it to this:
PRIMARY KEY (user_id, round_number, created_at)
I am doing this in phpmyadmin by clicking on the primary key icon in the table structure view.
This is the error I get:
#1025 - Error on rename of './database/#sql-2e0f_1254ba7' to './database/table' (errno: 150)
It is a MySQL database with InnoDB table engine.
Best Answer
There is probably another table with a foreign key referencing the primary key you are trying to change.
To find out which table caused the error you can run
SHOW ENGINE INNODB STATUS
and then look at theLATEST FOREIGN KEY ERROR
section.