我正在尝试创建下表
create table messaInScena ( data date, ora time, spazio varchar(20), spettacolo varchar(40), postiDisponibili smallint, prezzoIntero decimal(5,2), prezzoRidotto decimal(5,2), prezzoStudenti decimal(5,2), primary key (data, ora, spazio), foreign key (spazio) references spazio(nome) on update cascade on delete set null, foreign key (spettacolo) references spettacolo(titolo) on update cascade on delete set null, constraint RA3_1 check (postiDisponibili >= 0) ) ;
但出现以下错误:错误代码:1005无法创建表“ teatrosql.messainscena”(错误号:150)
外键引用的表是:
create table spazio ( nome varchar(20) primary key, indirizzo varchar(40) not null, pianta varchar(20), capienza smallint ); create table spettacolo ( titolo varchar(40) primary key, descrizione LONGBLOB, annoProduzione char(4) );
我已经验证了fk是唯一的,并且没有错别字(但也给了您一个您永远都不知道的:D控件)。如您所见,参考字段是主键。字段和fk之间的引用类型和尺寸重合..
我在哪里错了?
数据库的其他表
create table teatro ( nome varchar(20) primary key, telefono varchar(15), fax varchar(15), indirizzo varchar(40) not null, email varchar(30), url varchar(30) ); create table biglietteria ( nome varchar(20) primary key, indirizzo varchar(40) not null, email varchar(30), telefono varchar(15), teatro varchar(20), foreign key (teatro) references teatro(nome) on update cascade on delete set null ); create table orario ( biglietteria varchar(20), giorno varchar(10), inizio time, fine time, primary key(biglietteria, giorno, inizio), foreign key (biglietteria) references biglietteria(nome) on update cascade on delete cascade ); create table notizia ( data date, ora time, oggetto varchar(100), testo LONGBLOB, primary key(data, ora, oggetto) ); create table newsletter ( teatro varchar(20), data date, ora time, oggetto varchar(100), primary key(teatro, data, ora, oggetto), foreign key (teatro) references teatro(nome)on update cascade on delete cascade, foreign key (data, ora, oggetto) references notizia(data, ora, oggetto) on update cascade on delete cascade ); create table dipendente ( cf char(16) primary key, nome varchar(20) not null, cognome varchar(20) not null, dataDiNascita date, luogoDiNascita varchar(20), residenza varchar(30), telefonoFisso varchar(15), telefonoMobile varchar(15), email varchar(30) ); create table lavoro ( teatro varchar(20), dipendente char(16), dataAssunzione date, ruolo varchar(5), cda boolean, primary key(teatro, dipendente), foreign key (teatro) references teatro(nome) on update cascade on delete cascade, foreign key (dipendente) references dipendente(cf) on update cascade on delete cascade, constraint RA1 check ( cda = false or (year(current_date) - year(dataAssunzione) > 10) or (year(current_date) - year(dataAssunzione) = 10 and month(current_date) > month(dataAssunzione)) or (year(current_date) - year(dataAssunzione) = 10 and month(current_date) = month(dataAssunzione) and day(current_date) >= day(dataAssunzione)) ), check (ruolo in ('CA', 'POD', 'CUSRP', 'ACF')) ); create table stipendio ( dipendente char(16), inizio date, importo decimal(6,2), primary key(dipendente, inizio), foreign key (dipendente) references dipendente(cf) on update cascade on delete cascade ) ; create table luogo ( teatro varchar(20), spazio varchar(20), primary key(teatro, spazio), foreign key (teatro) references teatro(nome) on update cascade on delete cascade, foreign key (spazio) references spazio(nome) on update cascade on delete cascade ) ;
您可以检查InnoDB(SHOW ENGINE INNODB STATUS)的状态,以确定约束失败的确切原因。另一个选择是在创建表后添加外键约束。
SHOW ENGINE INNODB STATUS
就您而言,您似乎缺少引擎类型。列类型也必须匹配。被引用表上的主键很可能出现NOT NULL,而在中则不是messaInScena。
NOT NULL
messaInScena
create table spazio ( nome varchar(20) NOT NULL primary key, indirizzo varchar(40) not null, pianta varchar(20), capienza smallint ) ENGINE=InnoDB; create table spettacolo ( titolo varchar(40) NOT NULL primary key, descrizione LONGBLOB, annoProduzione char(4) ) ENGINE=InnoDB; create table messaInScena ( data date, ora time, spazio varchar(20) NOT NULL, spettacolo varchar(40) NOT NULL, postiDisponibili smallint, prezzoIntero decimal(5,2), prezzoRidotto decimal(5,2), prezzoStudenti decimal(5,2), primary key (data, ora, spazio), foreign key (spazio) references spazio(nome) on update cascade on delete set null, foreign key (spettacolo) references spettacolo(titolo) on update cascade on delete set null, constraint RA3_1 check (postiDisponibili >= 0) ) ENGINE=InnoDB;