oracle表级约束是什么,Oracle 常见的五种约束

(1)定义约束

198567991_1_20200807100809677

(2)列级约束\表级约束

198567991_2_20200807100809896.png

(3)非空约束NOT NULL

非空约束作用的列也叫强制列。顾名思义,强制列中必须有值,当然建表时候若使用default关键字指定了默认值,则可不输入。

198567991_3_20200807100809974

(4)唯一性约束unique

唯一性约束可作用在单列或多列上,对于这些列或组合,唯一性约束保证每一行的唯一性。

Unique需要注意:对于unique约束来讲,索引是必须的。如果不存在,就自动创建一个(unique的唯一本质上是通过索引来保证的)

Unique允许null值,unique约束的列可存在多个null。这是因为,unique唯一性通过btree索引来实现,而btree索引中不包含null。当然,这也造成了在where语句中null值进行过滤会造成全表扫描。

198567991_4_2020080710081083

(5)主键约束primary key

主键是定位表中单个行的方式,可唯一确定表中的某一行,关系型数据库要求所有表都应该有主键,不过Oracle没有遵循次范例要求,Oracle中的表可以没有主键(这种情况不多见)。关于主键有几个需要注意的点:

键列必须具有唯一性,且不能为空,其实主键约束相当于unique+not null  一个表只允许有一个主键

主键所在列必须具有索引(主键的唯一约束通过索引来实现),如果不存在,将会在索引添加的时候自动创建

注意:主键约束可以定义在表级也可以定义在列级(添加主键:约束的添加可在建表时创建,也可如下所示在建表后添加,一般推荐建表后添加,灵活度更高一些,建表时添加某些约束会有限制)

198567991_5_20200807100810208.png

(6)外键约束foreign key

外键约束定义在具有父子关系的子表中,外键约束使得子表中的列对应父表的主键列,用以维护数据库的完整性。不过出于性能和后期的业务系统的扩展的考虑,很多时候,外键约束仅出现在数据库的设计中,实际会放在业务程序中进行处理。外键约束注意以下几点:

外键约束的子表中的列和对应父表中的列数据类型必须相同,列名可以不同

对应的父表列必须存在主键约束(Primary key)或唯一约束(unique)

外键约束允许null值,对应的行就成了孤行了

其实很多时候不使用外键,很多人认为会让删除操作比较麻烦,比如要删除父表中的某条数据,但某个子表中又有对该条数据的引用,这时就会导致删除失败。我们有两种方式来优化这种场景:

第一种方式简单粗暴,删除的时候,级联删除掉子表中的所有匹配行,在创建外键时,通过 on delete cascade 子句指定该外键列可级联删除:

alter tableempadd constraintemp_deptno_fkforeign key(deptno)referencesdept(deptno)on delete cascade;

第二种方式,删除父表中的对应行,会将对应子表中的所有匹配行的外键约束列置为null,通过on delete set null子句实施:

alter tableempadd constraintemp_deptno_fkforeign key(deptno)referencesdept(deptno)on delete set null;

实际上,外键约束列和对应的父表列可以在同一张表中,常见的就是表的业务逻辑含义是一棵树,最简单的例子如下(id为主键id,fid为父id,fid存储对id的引用),这种结构的表根据业务要求可通过Oracle的递归查询来获取这种层级关系

198567991_6_20200807100810287

注意:外键约束可以定义在表级也可以定义在列级

foreignkey:在表级指定子表中的列

references:标示在父表中的列

nodeletecascade(级联删除):当父表中的列被删除时,字表中相对应的列也被删除

nodeletesetnull(级联置空):子表中相应的列置空

198567991_7_20200807100810396

198567991_8_20200807100810537.png

(7)检查约束check约束

检查约束可用来实施一些简单的规则,比如列值必须在某个范围内。检查的规则必须是一个结果为true或false 的表达式,比如:

198567991_9_20200807100810615

alter tableempadd constraintemp_sex_ckcheck(sexin('男','女'));

alter tabletest31add constraintchkkcheck(sex ='男' orsex='女');

alter tabletest34add constraintch_test34check(age>0 andage<120);

alter tabletest34add constraintch_test34check(agebetween 12 and 30);--在一个范围中间

alter tabletest36add constraintch_test36check(length(password)=6);--长度大于某个值

alter tabletest36add constraintemailcheck(emaillike '%@%');--电子邮箱要含有@符号

alter tabletest36add constraint password check((password like '00[0-9][0-9]/_[a-z,A-Z][a-z,A-Z][a-z,A-Z]%' escape '/')and(length(password)=8) )

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值