
•primary key与unique key都是唯一性约束。但二者有很大的区别:
•1.作为primary key的1个或多个列必须为NOT NULL,
• 如果建表时此列设为NULL,在增加PRIMARY KEY时,列自动更改为NOT NULL。
• 而unique key约束的列可以为null,这是primary key与unique key最大的区别。
•2.一个表只能有一个primary key(单列或多列,多列主键叫联合主键),但可以有多个unique key。
•实例1:
•create table t(c1 number(2),c2 date,c3 varchar2(5),c4 int) •desc t
•Name TypeNullable Default Comments
•---- ----------- -------- ------- --------
•C1 NUMBER(2) Y
•C2 DATEY
•C3 VARCHAR2(5) Y
•C4 INTEGER Y
•// •实例2:添加primary key
•alter table t add constraint t_pk primary key(c1,c2)
•desc t
•Name TypeNullable Default Comments
•---- ----------- -------- ------- --------
•C1 NUMBER(2)
•C2 DATE
•C3 VARCHAR2(5) Y
•C4 INTEGER Y
•我们看到,将c1,c2列设为联合主键后,他们变为not null; •如果在建表时就指定了主键的话,主键列将会默认为not null。 •// •如果我们在添加一个primary key,那么我们将会得到一个错误:
•alter table t add constraint t_pk_2 primary key(c3,c4)
•ORA-02260: table can have only one primary key
•// •实例3:添加unique key
•alter table t add constraint unique_key_t unique(c3,c4)
•实例4:添加数据
•insert into t(c1,c2,c3,c4)
•values(10,sysdate,'abc',3) •1 row inserted
•// •insert into t(c1,c2,c3,c4)
•values(11,sysdate,'abc',3) •ORA-00001: unique constraint (SCOTT.UNIQUE_KEY_T) violated
•我们看到,添加的第二条数据违反了刚刚创建的唯一键约束
•将unique_key_t删除,添加就能成功了。
•实例5:删除unique key
•alter table t drop constraint unique_key_t
•insert into t(c1,c2,c3,c4)
•values(11,sysdate,'abc',3) •1 row inserted
•// •实例6:删除primary key
•alter table t drop constraint t_pk
•Table altered
•// •desc t
•Name TypeNullable Default Comments
•---- ----------- -------- ------- --------
•C1 NUMBER(2) Y
•C2 DATEY
•C3 VARCHAR2(5) Y
•C4 INTEGER Y
•删除主键约束后,c1,c2列由恢复了原来的默认值null。 •// •3.其实primary key也是unique key,被primary key约束的列not null,并且不允许重复 •实例7:
•truncate table t
•Table truncated
•// •alter table t add constraint t_pk primary key(c1,c2)
•Table altered
•// •insert into t(c1,c2,c3,c4)
•values(1,to_date('2011-01-01','yyyy-mm-dd'),'csdn',10) •1 row inserted
•// •insert into t(c3,c4)
•values('china',1) •ORA-01400: cannot insert NULL into ("SCOTT"."T"."C1") •// •insert into t(c1,c2,c3,c4)
•values(1,to_date('2011-01-01','yyyy-mm-dd'),'csdn',10) •ORA-00001: unique constraint (SCOTT.T_PK) violated
•这里,我们看到primary key t_pk变成了unique约束,证明了主键约束也是唯一约束。
有两种方法:1. 将字段设置为主码(一个表只能定义一个主码):
a.创建表时设置主码:语句格式
create teable 表名( 字段名 类型及长度 PRIMARY KEY,...)
b.创建完表后给表添加主码(前提条件:表无主码,且将要设置为主码的列必须不允许空值、已存在的值不允许重复)
alter table 表名 add primary key(列名)
2. 设置字段为唯一值约束(一个表可以定义多个唯一值约束):
a. 创建表时设置唯一值约束
create table 表名(... , 字段名 类型及长度 UNIQUE, ...)
b.创建完表后添加唯一值约束(前提条件:将要设置唯一值约束的列已存在的值必须不重)
alter table 表名 add unique(列名)
约束用于限制加入表数据的类型,目的是保证数据的一致性和完整性创建格式:在创建表时规定约束(在Create添加),也可以在创建之后添加(Alter table)。
约束类型:NOT NULL、UNIQUE、PRIMARY KEY、FOREIGN KEY、CHECK、DEFAULT。
非空约束就是限制必须为某个列提供值,不允许有空值的存在。
空值(NULL)是不存在的值,它既不是数字0也不是空字符串,而是不存在未知的情况,即:该列的所有值不能为空,但可以为空字符或者0。
结果:通过desc查看会发现Nullable那一列的Y消失,表示此列不能为空。且在插入数值的时候此列必须添加数值,否则会报错。
取消非空约束使用alter方法:alter table test1 modify Author null 设置test1的Author可以
唯一性约束强调所在的列不允许有相同的值,但可以有多个Null。
其定义比主键约束弱,即他的列允许有空值(主键不允许有空值),唯一性约束的主要作用是保证在除主键外,其他列值得唯一性。
即:直接在列后面添加unique,
或在列后面添加 constraint 约束名 unique,
或在最后添加constraint 约束 unique(列名),
或者alter table 表名 add constraint 约束名 unique(列名)
建议使用的方法为alter和在最后添加最后添加constraint 约束 unique(列名)。
注:添加约束名的好处为:便于删除 *** 作,在删除时需要通过约束名来完成 *** 作。同时如果不添加约束名则系统会自动生成约束名,在表移动等 *** 作时,约束名也会更改,会造成后期 *** 作的麻烦。
取消唯一性约束:alter table test3 drop constraint QQ_UK2
主键约束唯一地标识了每一行记录(非空+唯一),在一个表中,最多只能有一个主键约束,主键约束既可以由一个列组成,也可以由两个或两个以上列组成(这种称联合主键)。
具体的方法和添加唯一约束相同,建议使用的方法为alter和在最后添加最后添加constraint 约束 unique(列名)。
删除主键:alter table 表名 drop constraint 约束名
外键约束主要是在B表中的某一列受到A表的制约,B的那一列的值只能是A内的值,比如工资表的员工号必须受员工表的员工号限制一样,工资表不能有不存在的员工号。
一般外键约束会使用两个表进行关联,外键是指"当前表"引用"另一个表"的某一列或某几列。在另一个表中,被引用的列必须具有主键约束或者唯一性约束,不存在的数据不能出现在当前表的对应列中。一般情况下当删除被引用表中数据时,该数据也不能出现在外键列中,如果存在则删除失败。
删除外键约束:alter table test5_1 drop constraint FK_test_5_1
check约束是为了让表中某字段值只能输入固定的值。
check设置数值范围:constraint check 表名 check (列名 between 小范围 and 大范围)
设置为大写:constraint check 表名 check (列名 = upper(列名))
取消 alter table test6_2 drop constraint check_test_6_2
默认约束是设置列的默认值,即当插入一行时,若不给出该列的值,就用默认值代替。
结果:在添加数据的时候,如果在设置有默认值的列没有添加数据则会把默认值添加进去。
取消默认约束 alter table test2 modify BOOKNAME default null
注:
add用于修改字段类型和长度的(即修改字段的属性)
modify修改表的数据结构。
update是修改数据内容的。
drop是删除数据内容。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)