Oracle基础 (八) 数据完整性

一、数据完整性

  数据完整性要求数据库中的数据具有准确性。准确性是通过数据库表的设计和约束来实现的。为了实现数据完整性,数据库需要做两方面的工作:

  • 确保每行的数据符合要求。
  • 去报没咧的数据符合要求。

  为了实现以上要求,Oracle提供了一下4种类型的约束(Constraint)。

  

  1、实体完整性约束

  实体完整性要求表中的每一行数据都反映不同的实体,不能存在相同的数据行。通过主键约束,唯一约束来实现实体完整性。

  (1)主键约束:

  表中的一列或者纪略组合的值能用来唯一的表示表中的每一行,这样的一列或者多列的组合叫做表的主键。

  主键自带唯一性,并且不能为空,一个表只能有一个主键,主键确保了表中数据行的唯一,同一张表中,可以使用多个列共同作为主键。在选择主键时,应遵循两个原则,最少性和稳定性。

  (2)唯一约束:

  保证数据行中的某一列的数据是唯一的,不重复的。这样可以添加唯一约束。

  唯一约束和主键的区别:

  • 主键不能为空,唯一可以为空,但只允许有一个空值。
  • 主键一张表中只有一个,而唯一可以有多个。
  • 主键可以由多个表来组成,唯一只能是单列。
  • 主键可以作为其他表的外键,唯一不可以。

  

  2、域完整性:

  与完整性是指给定咧的输入的有效性。通过数据类型、检查约束、输入格式、外键约束、默认值、非空约束等方法来实现。

  

  3、引用完整性:

  引用完整性是指为两个表中存在一定的联系,从而保证数据的完整性。例如:班级和学生,学生所在班级一定是在班级表中所存在的,不然就会出现不准确。引用完整性我们可以通过外键约束来实现。

  4、自定义完整性:

  用户自己定义约束规则。主要通过存储过程和触发器对象来实现。

二、添加约束

  在创建表时,我们可以再字段后添加各种约束。这里分为列级定义和表级定义:

  1、列级定义

  列级定义是指在定义列的同时定义定义约束。

  如在t_class表定义主键和唯一约束  

--创建班级表
CREATE TABLE t_class
(
  cid NUMBER CONSTRAINT pk_cid PRIMARY KEY,         --为cid添加主键约束
  cname VARCHAR2(20) constraint uq_sortname UNIQUE  --为cname添加唯一约束
)

  说明:在列级定义时,加不加constraint pk_department都是可以的,区别是不加的话,系统会自动分配一个主键约束名称,可读性差。

  2、表级定义

  表级定义是指在定义了所有列后,再定义约束。需要注意:not null只能在列级上定义。

  以在建立学生和班级表时定义主键约束和外键约束为例:  

--创建学生表
create table t_student(
    stuID number(4),
    stuname varchar2(20) NOT NULL,
    stupass varchar2(20) NOT NULL,
    cid NUMBER NOT NULL,
       constraint uq_username UNIQUE(stuname),  --创建唯一约束
       constraint ck_userpass Check(LENGTH(stupass) > 3),  --创建检查约束(密码长度大于3位)
    constraint pk_uid primary key(stuID), --主键约束
    constraint fk_cid foreign key(cid) references t_class(cid) --外键约束
  );

  

  3、创建表后,我们也可以在已经建好的表上添加约束,需要使用ALTER TABLE语句。

  语法:ALTER TABLE ADD CONSTRAINT 约束名 约束类型 具体的约束说明。  

ALTER TABLE t_student
    ADD CONSTRAINT uq_username UNIQUE(stuname)  --创建唯一约束
    ADD CONSTRAINT ck_userpass Check(LENGTH(stupass) > 3)   --创建检查约束(密码长度大于3位)
  ADD CONSTRAINT pk_uid primary key(stuID) --主键约束
  ADD CONSTRAINT fk_cid foreign key(cid) references t_class(cid) --外键约束

三、删除约束

  语法:ALTER TABLE DROPCONSTRAINT 约束名   

ALTER TABLE t_student
    DROP CONSTRAINT PK_UID

四、查看约束

  查看T_STUDENT表中所有的约束。注意:这里的表明必须全大写否则查不到结果。

SELECT * FROM USER_CONSTRAINTS
WHERE table_name = ‘T_STUDENT‘
时间: 2024-12-29 11:29:37

Oracle基础 (八) 数据完整性的相关文章

【转载:Oracle基础知识】Oracle数据库体系结构

先来看张直观的图:                                            oracle 11g 体系结构图 理解Oracle体系结构要充分理解三个概念:数据库(database),数据库实例(instance),会话(session),一定不要把这三个概念弄混. 数据库的概念 (A)    物理存储结构由数据文件.控制文件.重做日志文件组成: 1.       数据文件(datafile) select * from dba_data_files; 数据文件包括存

Oracle学习(八):处理数据

1.知识点:能够对比以下的录屏进行阅读 SQL> --SQL语句 SQL> --1. DML语句(Data Manipulation Language 数据操作语言): insert update delete select SQL> --2. DDL语句(Data Definition Language 数据定义语言): create/alter/drop/truncate table SQL> -- create/drop view,create/drop index(sequ

Oracle基础实训

一.Oracle基础SQL练习 班级表:班级编号(主键.标识列).班级名称.班主任.开班日期老师表:老师编号(主键.标识列) .姓名.性别(默认值‘男’).身份证号(必须是18位数字).联系电话学生表:学号(主键.固定五位数字) .班级编号.姓名.性别.出生日期.联系电话.家庭地址成绩表:编号(主键.标识列) .学号.科目名称.分数 1.表格创建 create table();语法 CREATE TABLE [schema.]table (column datatype [DEFAULT exp

Oracle基础知识笔记(10) 约束

大清早打开vs2008,出现这么诡异的错, 删了一个dll的就好了.如图 Oracle基础知识笔记(10) 约束

Oracle基础 shutdown和startup

原文:Oracle基础 shutdown和startup 一.shutdown命令:SHUTDOWN有四个参数:NORMAL.TRANSACTIONAL.IMMEDIATE.ABORT.缺省不带任何参数时表示是NORMAL. SHUTDOWN NORMAL:不允许新的连接.等待会话结束.等待事务结束.做一个检查点并关闭数据文件.启动时不需要实例恢复. SHUTDOWN TRANSACTIONAL:不允许新的连接.不等待会话结束.等待事务结束.做一个检查点并关闭数据文件.启动时不需要实例恢复. S

Oracle基础学习3--Oracle创建用户并授权

Oracle服务器端的操作一般如下: 1)       安装Oracle服务器软件 2)       创建数据库(安装时自动创建) 3)       配置监听(安装时自动配置) 4)       启动Oracle实例 5)       创建用户表空间 6)       创建新用户并授权 下面就开始讲创建用户表空间.创建新用户并授权两项: 首先要用系统管理员登陆Oracle(sqlplus/as sysdba) ?  创建用户表空间(D盘根目录创建名为ts_zhangsan的表空间) create

Oracle基础 数据库备份和恢复

原文:Oracle基础 数据库备份和恢复 一.为什么需要数据备份 造成数据丢失的主要原因: 1.介质故障. 2.用户的错误操作. 3.服务器的彻底崩溃. 4.计算机病毒. 5.不可预料的因素. Oracle中故障类型分为以下4种. 1.语句故障: 执行SQL语句过程发生的逻辑故障可导致语句故障.如果用户编写的SQL语句无效,就会发生语句故障.Oracle可自我修复语句故障,撤销语句产生的而印象,并将控制权交给应用程序. 2.用户进程故障 当用户程序出错而无法访问Oracle数据库时,就会发生用户

Oracle基础知识笔记(11) 建表、更新、查询综合练习

有某个学生运动会比赛信息的数据库,保存了如下的表: 运动员sporter(运动员编号sporterid,运动员姓名name,运动员性别sex,所属系号department) 项目item(项目编号itemid,项目名称itemname,项目比赛地点location) 成绩grade(运动员编号id,项目编号itemid,积分mark) 请用SQL语句完成如下功能: 1.  建表,并在相应字段上增加约束: 定义各个表的主键和外键约束: 运动员的姓名和所属系别不能为空: 积分要第为空值,要么为6,4

Oracle基础学习1--Oracle安装

安装过程较简单,按着步骤走即可.这里需要提醒如果要使用PL/SQL来操作Oracle,那么最好安装32位Oracle程序.原因是网上说PL/SQL只对32位Oracle进行支持,如果用64为Oracle+PL/SQL协同工作,会出现许多问题,例如无法加载oci.dll等.自己当然也亲自经历过,64位的Oracle单独使用很好,但相应的PL/SQL Developer却较难配置. 安装过程需要注意两个地方: ?  全局数据库名: ?  系统用户的密码(一般默认即可) 如何验证安装成功?按着自己的经

Oracle基础及三层分页查询

一.数据库表空间和数据文件 解析:一个数据库下可以开N个表空间,一个表空间可以包含N个数据文件.表空间是逻辑概念. 二.关于listener.ora位置 修改该界面上的数据,会影响指定路径的监听配置文件 D:\app\asus\product\11.2.0\dbhome_2\NETWORK\ADMIN 三.数据库和实例的关系 数据库(database):物理操作系统文件或磁盘(disk)的集合.使用Oracle 10g的自动存储管理(Automatic Storage Management,AS