postgresql foreign key syntax

前端 未结 1 1465
感情败类
感情败类 2020-12-22 16:59

I have 2 tables as you will see in my posgresql code below. The first table students has 2 columns, one for student_name and the other student_id which is the primary key.

相关标签:
1条回答
  • 2020-12-22 17:54

    Assuming this table:

    CREATE TABLE students 
    ( 
      student_id SERIAL PRIMARY KEY,
      player_name TEXT
    );
    

    There are four different ways to define a foreign key (when dealing with a single column PK) and they all lead to the same foreign key constraint:

    1. Inline without mentioning the target column:

      CREATE TABLE tests 
      ( 
         subject_id SERIAL,
         subject_name text,
         highestStudent_id integer REFERENCES students
      );
      
    2. Inline with mentioning the target column:

      CREATE TABLE tests 
      ( 
         subject_id SERIAL,
         subject_name text,
         highestStudent_id integer REFERENCES students (student_id)
      );
      
    3. Out of line inside the create table:

      CREATE TABLE tests 
      ( 
        subject_id SERIAL,
        subject_name text,
        highestStudent_id integer, 
        constraint fk_tests_students
           foreign key (highestStudent_id) 
           REFERENCES students (student_id)
      );
      
    4. As a separate alter table statement:

      CREATE TABLE tests 
      ( 
        subject_id SERIAL,
        subject_name text,
        highestStudent_id integer
      );
      
      alter table tests 
          add constraint fk_tests_students
          foreign key (highestStudent_id) 
          REFERENCES students (student_id);
      

    Which one you prefer is a matter of taste. But you should be consistent in your scripts. The last two statements are the only option if you have foreign keys referencing a PK that consists of more than one column - you can't define the FK "inline" in that case, e.g. foreign key (a,b) references foo (x,y)

    Only version 3) and 4) will give you the ability to define your own name for the FK constraint if you don't like the system generated ones from Postgres.


    The serial data type is not really a data type. It's just a short hand notation that defines a default value for the column taken from a sequence. So any column referencing a column defined as serial must be defined using the appropriate base type integer (or bigint for bigserial columns)

    0 讨论(0)
提交回复
热议问题