2 votes

problème de clé étrangère mysql

Quel est le problème avec l'ajout de la clé étrangère ici :

mysql> create table notes ( 
     id int (11) NOT NULL auto_increment PRIMARY KEY, 
     note_type_id smallint(5) NOT NULL, 
     data TEXT NOT NULL, 
     created_date datetime NOT NULL, 
     modified_date timestamp NOT NULL on update now()) 
     Engine=InnoDB;
Query OK, 0 rows affected (0.08 sec)

mysql> create table notetypes ( 
       id smallint (5) NOT NULL auto_increment PRIMARY KEY, 
       type varchar(255) NOT NULL UNIQUE) 
       Engine=InnoDB;
Query OK, 0 rows affected (0.00 sec)

mysql> alter table `notes` add constraint 
      foreign key(`note_type_id`) references `notetypes`.`id` 
      on update cascade on delete restrict;
ERROR 1005 (HY000): Can't create table './admin/#sql-43e_b762.frm' (errno: 150)  

Gracias

JP

1voto

bob Points 31

Je pense que le FK doit être nommé.

Essayez

ALTER TABLE `test`.`notes` ADD CONSTRAINT `note_type_id` FOREIGN KEY `note_type_id` (`note_type_id`)
    REFERENCES `notetypes` (`id`)
    ON DELETE RESTRICT
    ON UPDATE CASCADE;

0voto

shantanuo Points 4739
mysql> create table notes ( id int (11) NOT NULL auto_increment PRIMARY KEY, note_type_id smallint(5) NOT NULL, data TEXT NOT NULL, created_date datetime NOT NULL, modified_date timestamp NOT NULL on update now()) Engine=InnoDB;
Query OK, 0 rows affected (0.38 sec)

mysql> create table notetypes ( id smallint (5) NOT NULL auto_increment PRIMARY KEY, type varchar(255) NOT NULL UNIQUE) Engine=InnoDB;
Query OK, 0 rows affected (0.74 sec)

mysql> alter table `notes` add constraint foreign key(`note_type_id`) references notetypes (id)  on update cascade on delete restrict;
Query OK, 0 rows affected (0.64 sec)
Records: 0  Duplicates: 0  Warnings: 0

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X