小编典典

MySQL错误1005:无法建立表格(错误编号:150)

sql

我正在尝试创建下表

 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
  ) ;

阅读 184

收藏
2021-04-22

共1个答案

小编典典

您可以检查InnoDB(SHOW ENGINE INNODB STATUS)的状态,以确定约束失败的确切原因。另一个选择是在创建表后添加外键约束。

就您而言,您似乎缺少引擎类型。列类型也必须匹配。被引用表上的主键很可能出现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;
2021-04-22