在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

oracle中数据完整性的示例分析

130次阅读
没有评论

共计 2464 个字符,预计需要花费 7 分钟才能阅读完成。

丸趣 TV 小编给大家分享一下 oracle 中数据完整性的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

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)

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;

看完了这篇文章,相信你对“oracle 中数据完整性的示例分析”有了一定的了解,如果想了解更多相关知识,欢迎关注丸趣 TV 行业资讯频道,感谢各位的阅读!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-20发表,共计2464字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 肉色网站 | 在线91精品亚洲网站精品成人 | 97久久国产一区二区三区四区 | 婷婷久久久亚洲欧洲日产国码av | 日韩精品视频一区二区三区 | 亚洲av无码一区二区三区观看 | 久久电影网午夜鲁丝片免费 | 蜜臀av色欲a片无码精品一区 | 亚欧洲精品在线视频免费观看 | 亚洲一区在线观看视频 | 福利一区二区 | 欧美精品亚洲网站 | 亚洲va欧美va国产综合久久 | 黄视频免费在线看 | 欧美人交性视频在线香蕉 | 国产精品多p对白交换绿帽 国产精品多人p群无码 | 一区二区三区视频在线观看 | 国产福利在线观看视频 | 真实国产老熟女粗口对白 | 99热这里只有精品1 99热这里只有精品3 | 四虎2020紧急免费入口 | 日本粉色视频 | 日韩中文字幕视频在线观看 | 免费福利影院 | 国产一级做a爰片久久毛片男男 | 天天躁日日躁狠狠很躁 | 国产女人18毛片水真多 | 丰满人妻一区二区三区无码av | 亚洲色婷婷久久精品av蜜桃久久 | 亚洲色成人网一二三区 | 毛片在线播放观看日本 | 亚洲天堂2017无码中文 | 国产免费亚洲 | 在线va无码中文字幕 | 国产欧美日韩一区二区三区 | 国产精品激情福利视频 | 久久99热久久精品 | 亚洲一区 日韩精品 中文字幕 | 99re热这里只有精品视频 | 久久久久久亚洲av无码专区 | 欧美丰满大乳高跟鞋 |