五、完整性约束

就是正确性、准确性,包含三种:

  • 实体完整性
  • 参照完整性
  • 用户自定义完整性

Oracle中主要通过约束、触发器、过程函数实现的。

维护数据的完整性

有not null、unique、check、primary key、foreign key五种。
not null例如学生的姓名;unique例如学生的学号;primary key主键、foreign key外键、check可以按照用户要求,进行自动检查。
unique不可以重复,但是可以为空。
primary key不可以重复,也不能为空。一个表只能一个primary key,却可以多个unique。
not null只能在列内定义,其他4种约束可以在列定义结束后,在表内定义。

not null示例(这里的not null约束由系统自动起名)create table yg2(bh number(4) not null,xm varchar2(8)); 
check示例:
create table yg3(bh number(4) not null  check (bh>0  and  bh<10000),   xm varchar2(8));
unique示例:
create table yg4(部门号 number(4) not null, 部门内号  number(4) ,   xm varchar2(8) , 
   unique(部门号,部门内号) );
default的使用 
  create table gz_新员工  
   (bh number(4),xm varchar2(8),
      gz number(10) default 1000 );
适用于没有向列显式的指定数值的情况。


primary key示例(此列不允许为空,而且
ORACLE会自动为主键列创建索引,这里的
primary key约束由用户显式起名)create table student(xh number(6)  constraint code_pk  primary key , xm varchar2(20));

foreign key示例(实现两个表之间参照与被参
照的关系,外键只能取主键已经有的值,这里
的foreign key由系统自动起名):
create table address (xh number(8) ,zz varchar2(50) , foreign key(xh) references student(xh));


试验primary keyforeign key约束:
insert into student values(1,'张一');
insert into address values(1,'郑州'); 

insert into address values(2,'郑州'); 
(3)用户的约束在user_constraints表、和user_cons_columns表中 
 select * from user_constraints;


建立主键的五种方式

create table users1 (userid varchar2(10) primary key , username varchar2(20)); -- 主键名字,Oracle起的
create table users2 (userid varchar2(10) constraint pk_users2 primary key , username varchar2(20)  ); -- 主键名字,自己指定
create table users3 (userid varchar2(10) , username varchar2(20) , primary key( userid) ); -- 主键名字,Oracle起的

create table users4 (userid varchar2(10) , username varchar2(20) , CONSTRAINTS pk_users4 primary key (userid ) );  --主键名字,自己指定
create table users5 (userid varchar2(10) , username varchar2(20) );
alter table users5 add  CONSTRAINTS pk_users5 primary key (userid ) ;  --后来加上主键。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

问题:
建立2个表,一个是stuInfo(学号sno,姓名
sname,年龄sage,性别smale,系编号
deptNo),一个是department(系编号deptNo,
系名称deptName)。
 要求:
    每个表有主键。
    stuInfo表建立外键。
    学生的姓名不能为空。
    学生的年龄要在1850之间。
    学生的性别必须是男女之一,默认是男。
    stuInfo表的deptNo列,要参照department表的
deptNo列。

在这里插入图片描述

给已有的表添加约束

除了添加not null需要使用modify命令,其他都是类似alter table tablename  add  CONSTRAINTS的方式。
上面例子,允许stuInfo中的姓名可以为空:alter table stuinfo modify sname null;
允许stuInfo中的姓名不能重复:alter table stuinfo  add constraints  sname_unique  unique(sname) ;
要求department的系名称列的内容,必须大于4个字符长度:alter table 
department add constraints  deptName_check  check(length(deptName)>4);

清空回收站

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

删除约束

alter table 表名 drop constraint 约束名;
alter table department drop constraint deptName_check;  -- 删除刚才建立的department表上的deptName_check 约束
删除主键语句:alter table 表名 drop primary key;
   如果出错:ORA-02273: 此唯一/主键已被某些外键引用,可以:alter table department drop primary key cascade;
   如果删除一个主键被引用的表,可以:drop table 表名 cascade constraints;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值