| 数据完整性 / 引用完整性 | |
CREATE TABLE accounts (
          acc_num SERIAL primary key,
          acc_type INT,
          acc_descr CHAR(20));
          
          CREATE TABLE sub_accounts (
          sub_acc INTEGER primary key,
          ref_num INTEGER REFERENCES accounts (acc_num)
          ON DELETE CASCADE,
          sub_descr CHAR(20));
accounts 表的主键,acc_num 列,使用 SERIAL 数据类型,sub_accounts 表的外键,ref_num 列,使用 INTEGER 数据类型。允许组合主键上的 SERIAL 与外键上的 INTEGER 数据类型。仅在此条件下,您可混合并匹配数据类型。SERIAL 数据类型是 INTEGER,且数据库自动地为该列生成值。所有其他主键与外键组合都必须显式地相匹配。例如,定义为 CHAR 的主键必须与定义为 CHAR 的外键相匹配。
sub_accounts 表的外键的定义,ref_num 列,包括 ON DELETE CASCADE 选项。此选项指定在父表 accounts 中任何行的删除都将自动地导致删除子表 sub_accounts 的对应行。
DELETE FROM accounts WHERE acc_num = 2;