sql >> Databasteknik >  >> RDS >> Mysql

mysql främmande nyckelreferens från en sammansatt nyckel

MySQL har många restriktioner för främmande nycklar . Bland de som kan komma i vägen för dig. . .

  • Båda tabellerna måste använda INNODB-motorn.
  • "I referenstabellen måste det finnas ett index där kolumnerna för främmande nyckel är listade som de första kolumnerna i samma ordning. "

Den här koden fungerar i min version (5.1.62).

create table DEP_FACULTY(
  LNAME varchar(50),
  FNAME varchar(50),
  EMAIL varchar(70) primary key
) ENGINE = INNODB;

insert into DEP_FACULTY values ('Gregor', 'Brandich', '[email protected]');

create table STUDENT(
  LNAME varchar(50),
  FNAME varchar(50),
  ID char(9) primary key,
  ASSIGNED_ADVISOR_EMAIL varchar(70),
  foreign key (ASSIGNED_ADVISOR_EMAIL) references DEP_FACULTY(EMAIL) ON DELETE SET NULL,
  IS_ADVISED tinyint(1)
) ENGINE = INNODB;

insert into STUDENT values ('Charmaine', 'DePeletier', 'cmd', '[email protected]', 1);

create table ADVISE_HIST(
  STUDENT_ID char(9),
  foreign key (STUDENT_ID) references STUDENT(ID),
  ACTUAL_ADVISOR_EMAIL char(70) NOT NULL,
  foreign key (ACTUAL_ADVISOR_EMAIL) references DEP_FACULTY(EMAIL),
  DATE_ADVISED date,
  primary key REF_ADVISE_HIST (STUDENT_ID, DATE_ADVISED)
) ENGINE = INNODB;

insert into ADVISE_HIST values ('cmd', '[email protected]', CURRENT_DATE);
insert into ADVISE_HIST values ('ctd', '[email protected]', CURRENT_DATE);

Av de två sista inläggen fungerar den första. Den andra bör ge ett begränsningsfel för främmande nyckel.




  1. Oracle Instant Client för ARM-baserad Debian-enhet

  2. Hur använder jag strukturella anteckningar för att ställa in SQL-typ till Date i modell första tillvägagångssätt

  3. Oracle får DISTINKT numerisk med en CLOB i frågan

  4. Välj med flera taggar