数据的完整性简介
一、 就是正确性、准确性,包含三种:实体完整性、参照完整性、用户自定义完整性。Oracle中主要通过约束、触发器、过程函数实现的。
二、 维护数据的完整性,有not null、unique、check、primary key、foreign key五种。
(1)not null例如学生的姓名;unique例如学生的学号;primary key主键、foreign key外键、check可以按照用户要求,进行自动检查。
(2)unique不可以重复,但是可以为空。
(3)primary key不可以重复,也不能为空。
(4)一个表只能一个primary key,却可以多个unique。
(5)not null只能在列内定义,其他4种约束可以在列定义结束后,在表内定义。
三、约束示例:
1、not null 约束
SQL> create table yg2(bh number not null,xm varchar2(8));
查询约束(只有一个not null约束,名称是系统根据规则随机产生
SQL> select u.CONSTRAINT_NAME,u.CONSTRAINT_TYPE,u.TABLE_NAME,u.INDEX_NAME from user_constraints u;
2、not null,check约束
SQL> create table yg3(bh number(4) not null check (bh>0 and bh<10000), xm varchar2(8));.
查看约束,已经是两个了,一个是not null,一个是check约束
(3)查看当前用户中,涉及到约束的列的情况(可以看到约束到编号的情况)
SQL> select * from user_cons_columns;
3、unique约束(会自动创建索引)
SQL> create table yg4(bumenID number not null,bumenneiID number,xm varchar2(8),unique(bumenID,bumenneiID));
查看约束(同时创建了索引):
select u.CONSTRAINT_NAME,u.CONSTRAINT_TYPE,u.TABLE_NAME,u.INDEX_NAME from user_constraints u order by constraint_name;
查询用户约束列
4、default约束
SQL> create table gz_newYG(bh number(4),xm varchar2(8),gz number(10) default 1000 );
5、主键和外键约束
a、primary key示例(此列不允许为空,而且ORACLE会自动为主键列创建索引,这里的 primary key约束由用户显式起名):
SQL>create table student(xh number(6) constraint code_pk primary key , xm varchar2(20));
b、foreign key示例(实现两个表之间参照与被参照的关系,外键只能取主键已经有的值,这里的foreign key由系统自动起名):
其中foreign key(xh) references student(xh)是指外键参照了student表中的xh
SQL>create table address (xh number(8) ,zz varchar2(50) , foreign key(xh) references student(xh));
c、测试:作为address中的外键,xh=2,必须在student表的主键中存在,否则报错
6、建立主键的五种方式:
a、create table users1 (userid varchar2(10) primary key , username varchar2(20)); -- 主键名字,Oracle起的
b、create table users2 (userid varchar2(10) constraint pk_users2 primary key , username varchar2(20) ); -- 主键名字,自己指定
c、create table users3 (userid varchar2(10) , username varchar2(20) , primary key( userid) ); -- 主键名字,Oracle起的
d、create table users4 (userid varchar2(10) , username varchar2(20) , CONSTRAINTS pk_users4 primary key (userid ) ); --主键名字,自己指定
e、create table users5 (userid varchar2(10) , username varchar2(20) );
alter table users5 add CONSTRAINTS pk_users5 primary key (userid ) ; --后来加上主键。
7、习题:
建立2个表,一个是stuInfo(学号sno,姓名sname,年龄sage,性别smale,系编号deptNo),一个是department(系编号deptNo,系名称deptName)。
要求:
每个表有主键。
stuInfo表建立外键。
学生的姓名不能为空。
学生的年龄要在18到50之间。
学生的性别必须是男女之一,默认是男。
stuInfo表的deptNo列,要参照department表的deptNo列。
方法一:
a、创建表department表
SQL> create table department(deptno char(4),deptname varchar2(20),constraints pk_department primary key(deptno));
b、创建stuInfo表,并创建外键
SQL> create table stuInfo(sno number constraints pk_stuinfo primary key,sname varchar2(10) not null,sage number check(sage>=18 and sage<=50),smale char(6) default 'male' check(smale='male' or smale='female') ,deptNo char(4),foreign key(deptno) references department(deptno));
方法二:
a、创建stuInfo表,
SQL>create table stuInfo(sno number constraints pk_stuinfo primary key,sname varchar2(10) not null,sage number check(sage>=18 and sage<=50),smale char(6) default 'male' check(smale='male' or smale='female') ,deptno char(4));
b、创建department表
SQL>create table department(deptno char(4),deptname varchar2(20),constraints pk_department primary key(deptno));
c、增加外键
SQL>alter table stuinfo add constraints fk_department foreign key(deptno) references department(deptno);
查看stuinfo表的约束,外键约束名称:CONSTRAINT_NAME是PK_DEPARMENT,参照R_CONSTRINT_NAME的名称是PK_DEPARTMENT。
查看department表的约束,主键济伟PK_DEPARTMENT
8、给已有的表添加约束
除了添加not null需要使用modify命令,其他都是类似alter table tablename add CONSTRAINTS的方式。 上面例子,
a、允许stuInfo中的姓名可以为空:
alter table stuinfo modify sname null;
b、允许stuInfo中的姓名不能重复:
alter table stuinfo add constraints sname_unique unique(sname) ;
c、要求department的系名称列的内容,必须大于4个字符长度:
alter table department add constraints deptName_check check(length(deptName)>4);
(9)删除约束
a、alter table 表名 drop constraint 约束名;
b、alter table department drop constraint deptName_check; -- 删除刚才建立的department表上的deptName_check 约束
c、删除主键语句:alter table 表名 drop primary key;
如果出错:ORA-02273: 此唯一/主键已被某些外键引用,可以:alter table department drop primary key cascade;
d、如果删除一个主键被引用的表,可以:drop table 表名 cascade constraints;(强制删除后,引用的表中,就不会存在这个外键约束了)
四、启用、禁用约束
暂停主键约束:(注意,暂停后,就可以对主键列插入重复的数据了。但因违反了唯一性约束,此时是无法再启用约束的)
SQL>alter table user7 disable primary key;
启用主键约束:
SQL>alter table user7 enable primary key;
文章评论