`

6、数据完整性、约束、范式等数据库知识点概述

 
阅读更多

数据完整性

数据库不仅仅是存储数据,它也必须保证所保存的数据的正确性。如果数据不正确或不一致,那么该数据的完整性可能会遭到破坏,从而给数据库本身的可靠性带来意想不到的问题。

为了维护数据库中的数据完成性,在创建表时通常需要指定一些约束。通过表中的字段()定义约束,就可以防止非法数据的插入问题.对约束的定义可以再create table语句中进行,也可以在alter table语句中进行。

什么是约束呢?

约束是表级的强制规定.根据约束的作用域,约束又可分为表级约束和列级约束两种。

列级约束是指是字段定义的一部分,只能够应用在一个列上.

表级约束是指独立于列的定义,可以应用于一个表中的多个列上。

oracle系统中定义约束时,通过constraint关键字为约束命名,如果用户没有为约束指定名称,系统会自动建立默认的名称。

总结:

l 作用范围:列级约束只能作用在一个列上,而表约束可以作用在多个列上(当然表约束也可以作用在一个列上)。

l 定义方式:列约束必须跟在列的定义里后面,表约束不与列一起,而是单独定义。

l 非空(not null) 约束只能定义在列上

备注:在定义约束时,可以通过指定enabledisable关键字将约束的初始状态设置为激活或禁用状态,默认是激活状态。

定义约束的语法格式1

CREATE TABLE [schema.]table

(column datatype [DEFAULT expr]

[column_constraint],

...

[table_constraint][,...]);

列级约束:

column [CONSTRAINT constraint_name] constraint_type,

表级约束

column,...

[CONSTRAINT constraint_name] constraint_type

(column, ...),

约束的分类为:

NOT NULL

UNIQUE

PRIMARY KEY

FOREIGN KEY

CHECK

1、 Not null

特点如下:

* 为字段定义not null 约束后,该字段不能为null

* Not Null约束只能在列级定义

* 在定义一个表中可以有多个not Null

2、 unique

特点如下:

* 如果为字段定义了unique约束,该字段不能够包含重复值

* unique约束既可以在列级定义,也可以在表级定义。

* oracle系统中被定义的unique约束会自动建立一个唯一的索引。

* 同一个字段既可以在其上定义为not null 也可以建立unique约束,(为某个字段可以添加多个约束),注意:如果在一个字段仅定义了unique约束,则该字段可以包含多个null

Unique主要的目的是:是在保证主键列外,其它列的唯一性。

3、 primary key

特点如下:

* 定义为primary key的字段或字段组中不能包含重复值,并且不能为null.(即满足唯一性,不能为空)

* 在一个表中只能定义一个primary key的约束

* Oracle会自动为具有primarykey约束的字段添加一个唯一的索引,以及一个not null约束

4、 foreign key

特点如下:

* 被定义了foreign key约束的字段的取值只能为相关表中引用的字段的值或null值。

* foreign key约束既可以在列级定义,也可以在表级定义。

* 定义了foreign key约束的外键字段和被引用的主键字段可以在同一张表中,这种情况称为:’自引用’(构成了自关联关系)

* 对于同一个字段可以同时定义为foreign key约束和not null约束。

注意:外键的类型、尺寸等一定要与主键完全一致。

备注:

oracle中级联删除有如下三值:

1、 no action 在删除一方的情况下,对多方不进行任何操作.(不能删,删的情况会出现, 违反完整约束条件的异常信息

2、 cascade

在删除一方的时,会把多方所有与1方关联的数据删除掉。

3、 set null

在删除一方的时,会把多方所有与1方关联的数据的字段值设置为null(注意:该字段必须允许为null 否则的话会出现无法更新*** NULL)

5、 check

check约束是所有约束中最灵活的约束,也是最复杂的约束,check约束检查输入到表中的数据值来维护域的完整性,即检查输入的每一个数据,只有符合条件的数据才允许输入到表中.check约束有如下特点:

* check约束的表达式中,必须引用表中一个或多个字段,并且表达式的运算结果必须是一个布尔值.

* Check约束即可以在列级定义,也可以在表级定义

* 对于同一个字段可以定义多个check约束,而且对于同一个字段可以定义check约束和not null约束。

综合案例:

学生信息表

用户名,用户密码,用户电话,用户邮箱,用户地址.

教师名称,教师性别,教师职务,教师年龄

——————————————————————————————

分析:满足1NF范式(属性不可再分)

满足2NF范式(非主属性必须完全依赖于任一候选键)

用户名->用户密码,用户电话,用户邮箱,用户地址.

Stusname,stel,semail,saddress

用户名—> 教师名称

教师名称—>用户名

stearsid,tname,sname

教师名称—>教师性别,教师职务,教师年龄

Teachertname,tsex,ttitle,tage

满足3NF(非主属性都不传递依赖于任一候选键)

//创建表的语法同时也给表加约束||或者是创建表之后才用alter语句添加约束条件

//第一步切换到管理员权限

SQL> conn system/root;

//第二步创建用户

SQL> create user slj identified by root;

//第三步为用户分配角色权限

SQL> grant connect,resource to slj;//connect 连接 resources 创建表的权限 详细参考第二次oracle课程

//切换到相应的用户

SQL> conn slj/root;

//采用create语句创建表

SQL> create table stu(

2 sname varchar2(20) primary key,

3 stel varchar2(11) not null,

4 semail varchar2(40),

5 saddress varchar2(50)

6 );

Table created

SQL> create table teacher(

2 tname varchar2(20) primary key,

3 tsex varchar2(2),

4 ttitle varchar2(40),

5 tage number(3) check(tage<100 and tage>20)

6 );

Table created

SQL> create table stear(

2 sid number(10) primary key,

3 tname varchar2(20) references teacher(tname),

4 sname varchar2(20) references stu(sname)

5 );

Table created

SQL> commit;

//查询约束条件

SQL> select * from user_constraints;

//查询被约束的列

SQL> select * from user_cons_columns;

分享到:
评论

相关推荐

    数据库范式理解例题数据库范式理解例题.doc

    数据库范式理解例题数据库范式理解例题

    数据库三大范式详解

    目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、第四范式(4NF)、第五范式(5NF)和第六范式(6NF)。满足最低要求的范式是第一范式(1NF)。在第一范式的基础上进一步满足更多...

    数据库设计三大范式应用实例剖析

    数据库的设计范式是数据库设计所需要满足的规范,满足这些规范的数据库是简洁的、结构明晰的,同时,不会发生插入、删除和更新操作异常。第一范式:数据库表中的字段都是单一属性的,不可再分。这个单一属性由基本...

    数据库系统范式教程数据库系统范式教程.ppt

    数据库系统范式教程数据库系统范式教程

    数据库设计范式数据库设计范式

    目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、第四范式(4NF)、第五范式(5NF)和第六范式(6NF)。满足最低要求的范式是第一范式(1NF)。在第一范式的基础上进一步满足更多...

    什么是数据库范式?什么是设计范式?

    目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、第四范式(4NF)、第五范式(5NF)和第六范式(6NF)。满足最低要求的范式是第一范式(1NF)。在第一范式的基础上进一步满足更多...

    数据库完整性部分练习题

    数据库的完整性的练习,作为数据库范式的一部分,数据库的完整性练习非常重要。

    数据库范式

    设计范式(范式,数据库设计范式,数据库的设计范式)是符合某一种级别的关系模式的集合。构造数据库必须遵循一定的规则。在关系数据库中,这种规则就是范式。关系数据库中的关系必须满足一定的要求,即满足不同的范式...

    数据库设计模式范式简介

    目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、第四范式(4NF)、第五范式(5NF)和第六范式(6NF)。满足最低要求的范式是第一范式(1NF)。在第一范式的基础上进一步满足更多...

    软件工程之专题六: 数据库知识

     数据库管理系统提供了四个方面的数据控制能力-数据完整性、数据安全性、数据库的并发控制、数据库的恢复 数据库的基本概念  数据库(DB):是存储在一起的相关数据的集合。DB能为各种用户共享,具有最小冗余度...

    架构师思维导图【数据库系统】

    架构师思维导图 数据库系统 规范化理论 并发控制 关系代数 数据库设计过程 数据库模式 数据完整性约束 数据库安全措施 数据备份与恢复 数据库技术拓展 数据库性能优化 函数依赖 Armstrong公理 键 范式 模式分解 无损...

    数据库设计三大范式

    此文档是关于数据库三大范式的描述,以及在何种情况下应该用何种范式已达到数据库的良好效率!

    数据库-范式及范式分解复习知识

    数据库-范式及范式分解复习知识

    数据库设计范式简单入门

    目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、第四范式(4NF)、第五范式(5NF)和第六范式(6NF)。满足最低要求的范式是第一范式(1NF)。在第一范式的基础上进一步满足更多...

    数据库范式化教程 - 订单数据实例速成.pdf

    数据库范式化教程 以订单数据实例 简明扼要讲解抽象的概念,易懂实用,推荐。

    数据库范式.pdf

    数据库范式.pdf

    三级数据库知识点学习(四)

    数据完整性约束 二、范式 范式即设计数据库时,需要遵循的一些规范。要遵循后面的要求,就必须遵循前面的所有范式要求。 关系数据库中共有6种范式,分别为 第一范式(1NF) 第二范式(2NF) 第三范式(3NF) BC范式 ...

    数据库范式【转】

    数据库范式【转】数据库范式【转】数据库范式【转】数据库范式【转】

    数据库函数依赖范式

    数据库函数依赖范式

    数据库设计培训.pptx

    良好的数据库设计: 节省数据的存储空间 能够保证数据的完整性 方便进行数据库应用系统的开发 糟糕的数据库设计: 数据冗余、存储空间浪费 内存空间浪费 数据更新和插入的异常 数据库设计培训全文共37页,当前为第3...

Global site tag (gtag.js) - Google Analytics