Mysql
 sql >> Database >  >> RDS >> Mysql

in mysql, su delete cascade non funziona

Se crei t2 in questo modo funziona bene:

CREATE TABLE  `t2` (
  `id` bigint(20) unsigned NOT NULL,
  `data2` text,
  PRIMARY KEY (`id`),
  CONSTRAINT `FK_t2_1` FOREIGN KEY (`id`) REFERENCES `t1` (`id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

ETA, in risposta alle preoccupazioni sul codice brutto, funziona anche il seguente:

CREATE TABLE  t2 (
  id bigint(20) unsigned NOT NULL PRIMARY KEY,
  data2 text,
  CONSTRAINT  FOREIGN KEY (id) REFERENCES t1(id) ON DELETE CASCADE
) ENGINE=InnoDB ;

La differenza principale è che il tipo di dati per t2.id deve corrispondere a quello di t1.id e i vincoli devono essere dichiarati dopo le colonne.