How can I add a foreign key when creating a new table?

后端 未结 5 1779
刺人心
刺人心 2020-12-17 16:18

I have these two CREATE TABLE statements:

CREATE TABLE GUEST (
  id int(15) not null auto_increment PRIMARY KEY,
  GuestName char(25) not null
         


        
相关标签:
5条回答
  • 2020-12-17 16:30

    The answer to your question is almost the same as the answer to this one .

    You need to specify in the table containing the foreign key the name of the table containing the primary key, and the name of the primary key field (using "references").

    This has some code showing how to create foreign keys by themselves, and in CREATE TABLE.

    Here's one of the simpler examples from that:

    CREATE TABLE parent (id INT NOT NULL,
       PRIMARY KEY (id)
    ) ENGINE=INNODB;
    CREATE TABLE child (id INT, parent_id INT,
       INDEX par_ind (parent_id),
       FOREIGN KEY (parent_id) REFERENCES parent(id)
       ON DELETE CASCADE
    ) ENGINE=INNODB;
    
    0 讨论(0)
  • 2020-12-17 16:41

    I will suggest having a unique key for the payment table. On it's side, the foreign key should not be auto_increment as it refer to an already existing key.

    CREATE TABLE GUEST(
        id int(15) not null auto_increment PRIMARY KEY, 
        GuestName char(25) not null
    )  ENGINE=INNODB;
    
    CREATE TABLE PAYMENT(
        id int(15)not null auto_increment, 
        Guest_id int(15) not null, 
        INDEX G_id (Guest_id), 
        Foreign Key(Guest_id) references GUEST(id),
        BillNr int(15) not null
    )  ENGINE=INNODB;
    
    0 讨论(0)
  • 2020-12-17 16:42

    There should be space between int(15) and not null

    0 讨论(0)
  • 2020-12-17 16:45

    Make sure you're using the InnoDB engine for either the database, or for both tables. From the MySQL Reference:

    For storage engines other than InnoDB, MySQL Server parses the FOREIGN KEY syntax in CREATE TABLE statements, but does not use or store it.

    0 讨论(0)
  • 2020-12-17 16:50
    create table course(ccode int(2) primary key,course varchar(10));
    
    create table student1(rollno int(5) primary key,name varchar(10),coursecode int(2) not 
    null,mark1 int(3),mark2 int(3),foreign key(coursecode) references course(ccode));
    
    0 讨论(0)
提交回复
热议问题