如何使用联合主键做外键
程序员文章站
2024-01-13 21:00:58
...
怎么使用联合主键做外键?
我有一个表的主键是联合主键,这个联合主键是在另一个表中的外键,这个应该怎么做?
例如:
CREATE TABLE IF NOT EXISTS customers(
firstname varchar(25) not null,
lastname varchar(25) not null,
certificatetype varchar(25) not null,
certificatenumber varchar(25) not null,
gender varchar(6) not null,
constraint uc_customerID primary key (certificatetype,certificatenumber)
);
CREATE TABLE IF NOT EXISTS cab_status(
ID int NOT NULL AUTO_INCREMENT PRIMARY KEY,
roomname varchar(10) not null,
certificatetype varchar(25) not null,
certificatenumber varchar(25) not null,
foreign key() references customer()
)";
我想把certificatetype,certificatenumber作为customers的主键,作为cab_status的外键,红色的地方应该怎么做呢?
因为人名有可能重复,所以我就像把证件类型和证件号码作为主键。
------解决方案--------------------
foreign key(certificatetype ,certificatenumber ) references customer(certificatetype ,certificatenumber )
我有一个表的主键是联合主键,这个联合主键是在另一个表中的外键,这个应该怎么做?
例如:
CREATE TABLE IF NOT EXISTS customers(
firstname varchar(25) not null,
lastname varchar(25) not null,
certificatetype varchar(25) not null,
certificatenumber varchar(25) not null,
gender varchar(6) not null,
constraint uc_customerID primary key (certificatetype,certificatenumber)
);
CREATE TABLE IF NOT EXISTS cab_status(
ID int NOT NULL AUTO_INCREMENT PRIMARY KEY,
roomname varchar(10) not null,
certificatetype varchar(25) not null,
certificatenumber varchar(25) not null,
foreign key() references customer()
)";
我想把certificatetype,certificatenumber作为customers的主键,作为cab_status的外键,红色的地方应该怎么做呢?
因为人名有可能重复,所以我就像把证件类型和证件号码作为主键。
------解决方案--------------------
foreign key(certificatetype ,certificatenumber ) references customer(certificatetype ,certificatenumber )
相关文章
相关视频
推荐阅读
-
如何使用联合主键做外键
-
如何获取SqlServer2005表结构(字段,主键,外键,递增,描述)_MySQL
-
使用 doctrine orm 如何在程序逻辑上实现在一张表完成两个外键的设置(或则说一个实体完成两个多对一的关系)?
-
如何区分SQL数据库中的主键与外键
-
如何区分SQL数据库中的主键与外键
-
使用TableHasPrimaryKey或TableHasForeignKey来知道表是否有主键或外键
-
简述MySQL主键和外键使用及说明
-
使用 doctrine orm 如何在程序逻辑上实现在一张表完成两个外键的设置(或则说一个实体完成两个多对一的关系)?
-
使用TableHasPrimaryKey或TableHasForeignKey来知道表是否有主键或外键
-
如何使用联合主键做外键