sql >> Database >  >> RDS >> Mysql

Gebruik samengestelde primaire sleutel als externe sleutel

De regel:

FOREIGN KEY (pk_studentID ) REFERENCES student(pk_studentID ),

is fout. Je kunt pk_studentID niet gebruiken zo, dit is gewoon de naam van de PK-beperking in de bovenliggende tabel. Om een ​​samengestelde primaire sleutel als externe sleutel te gebruiken, moet u hetzelfde aantal kolommen (die de PK vormen) met dezelfde gegevenstypes toevoegen aan de onderliggende tabel en vervolgens de combinatie van deze kolommen gebruiken in de FOREIGN KEY definitie:

CREATE TABLE files
(
  files_name varchar(50) NOT NULL, 

  batch_id varchar(4) NOT NULL,         --- added, these 3 should not
  dept_id varchar(6) NOT NULL,          --- necessarily be NOT NULL
  student_id varchar (25) NOT NULL,     --- 

  files_path varchar(50),
  files_data varchar(max),              --- varchar(max) ??   
  files_bookmarks xml,                  --- xml ??
                                        --- your question is tagged MySQL, 
                                        --- and not SQL-Server

  CONSTRAINT pk_filesName 
    PRIMARY KEY (files_name),

  CONSTRAINT fk_student_files                     --- constraint name (optional)
    FOREIGN KEY (batch_id, dept_id, student_id)  
      REFERENCES student (batch_id, dept_id, student_id)
) ENGINE = InnoDB ;



  1. Een datum weergeven als iso 8601-formaat met PHP

  2. MariaDB JSON-functies

  3. Hoe UNIX_TIMESTAMP() werkt in MariaDB

  4. Sql Server-replicatie vereist de daadwerkelijke servernaam om verbinding te maken met de server