oracle中数据完整性的示例分析
admin
2023-05-14 17:02:17
0

1.  数据的完整性简介

    就是正确性、准确性,包含三种:实体完整性、参照完整性、

用户自定义完整性。Oracle中主要通过约束、触发器、过程函数

实现的。 以下内容讲通过约束实现数据完整性。

举例两个表:

学生(学号,姓名,系编号)

系(系编号,系名称)

员工(编号,姓名,出生日期,工作日期)

那么:

学号是主键列,其值不能错误,如不能负值,这就是实体完整性;

系编号是外键,学生表的系编号参照系表,也就是说学生表的系编号的值必须在系表的系编号的值范围内【或者为空】,这就是参照完整性;

员工表的出生日期一定需要小宇工作日期,这就是用户自定义完整性。

2.  维护数据的完整性,有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 key和foreign 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;

实践练习题目:

问题:

建立2个表,一个是StudentInformatino(学号sno,姓名

sname,年龄sage,性别smale,系编号

deptNo),一个是department(系编号deptno,

系名称deptname)。

 要求:

    每个表有主键。

    StudentInformation表建立外键。

    学生的姓名不能为空。

    学生的年龄要在18到50之间。

    学生的性别必须是男女之一,默认是男。

    StudentInformation表的deptno列,要参照department表的

deptno列。

3.2 给已有的表添加约束:

除了添加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);

3.3 删除约束:

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;

相关内容

热门资讯

人工智能如何重塑电影行业?中国... 北京5月15日电 (记者 孙自法)人工智能生成内容(AIGC)正为众多行业带来深刻巨变,引发广泛关注...
济南隆超取得便捷式喷涂装置专利... 国家知识产权局信息显示,济南隆超石油机械锻造有限公司取得一项名为“一种便捷式喷涂装置”的专利,授权公...
原创 国... ## 国际空间站宇航员在微重力环境下与新鲜水果合影 维生素C很重要,即使在太空中也是如此。 来源:...
原创 低... 手机厂商的618活动陆续都开启了,在苹果宣布iPhone 17 Pro系列降价千元后,华为也迅速跟进...
微信第一行代码曝光! IT之家 5 月 15 日消息,据 CCF 计算机博物馆官方消息,2026 年 5 月 15 日,中...
光鼎电子取得LED数码管灌胶设... 国家知识产权局信息显示,连云港光鼎电子有限公司取得一项名为“一种LED数码管灌胶设备”的专利,授权公...
“兰州瓜农刺死城管”案二审维持... “兰州瓜农刺死城管”案有新进展。澎湃新闻从瓜农王爱文及其辩护律师处了解到,5月15日,甘肃省高院对此...
美国随访记者吐槽在北京被罚款,... 执笔/胡一刀&月半刀&宝刀刀美国福克斯新闻台的主持人,想在北京街头,拍一个阴阳中国社会治理的故事。当...
武大开放校门之争,别急着过度拔... □徐林生5月13日,武汉大学正式取消社会公众进校预约制度。公众无需任何预约,仅凭本人身份证即可在珞珈...
李羚专题调研我市“圆梦工程”未... 5月15日下午,中国社会工作联合会副会长李羚率调研组一行来鄂州,开展“圆梦工程”未成年人心理健康教育...