(
a int primary key,
b int not null unique
)
;
注:not null unique相当于主键,这样就形成了复合主键
建立联合主键有两种方式:
一种是在建表时就写出,语句如下:
Create Table 表名 (字段名1 Int Not Null,
字段名2 nvarchar(13) Not Null Primary Key (字段名1, 字段名2),
字段名3
字段名N )
另一种是在建表后更改,语句如下:
alter table 你的表名 add constraint pk_你的表名 primary key (字段1,字段2)
ALTER TABLE 表名 WITH NOCHECK ADD
CONSTRAINT [PK_表名] PRIMARY KEY NONCLUSTERED
(
[字段名1],
[字段名2]
)
创建联合主键还可以这样写:
create table huayunkeji_today(device_id int , year int, month int, day int, hour int, temperature float, humidity float,
primary key(device_id,year,month,day,hour));
扩展资料:
联合主键的使用情况及优点:
联合主键就是用2个或2个以上的字段组成主键。用这个主键包含的字段作为主键,这个组合在数据表中是唯一,且加了主键索引。
可以这么理解,比如,你的订单表里有很多字段,一般情况只要有个订单号bill_no做主键就可以了,但是,现在要求可能会有补充订单,使用相同的订单号,那么这时单独使用订单号就不可以了。
再使用个订单序列号bill_seq来作为区别。把bill_no和bill_seq设成联合主键。即使bill_no相同,bill_seq不同也是可以的。
create table 表名(a ,
b,
constraint 约束名 primary key(a,b)
);
如果是已建完表则 去添加 alter table table_name add constraint 约束名 primary key(a,b);例如:\x0d\已有一个表test_key,其中a1列为主键。\x0d\create table TEST_KEY\x0d\(\x0d\ a1 VARCHAR2(3) not null,\x0d\ a2 VARCHAR2(3),\x0d\ b1 VARCHAR2(3),\x0d\ b2 VARCHAR2(3)\x0d\);\x0d\ \x0d\alter table TEST_KEY\x0d\ add constraint PK_TEST_KEY primary key (A1)\x0d\ using index;\x0d\ \x0d\现在要将a2,b1也增加到主键中与原有的a1一起组成复合主键。语句如下:\x0d\alter table TEST_KEY\x0d\ drop constraint PK_TEST_KEY cascade;\x0d\alter table TEST_KEY\x0d\ add constraint PK_TEST_KEY primary key (A1, A2, B1)\x0d\ using index;\x0d\ \x0d\这样就可以了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)