数据完整性
数据库不仅仅是存储数据,它也必须保证所保存的数据的正确性。如果数据不正确或不一致,那么该数据的完整性可能会遭到破坏,从而给数据库本身的可靠性带来意想不到的问题。
为了维护数据库中的数据完成性,在创建表时通常需要指定一些约束。通过表中的字段(列)定义约束,就可以防止非法数据的插入问题.对约束的定义可以再create table语句中进行,也可以在alter table语句中进行。
什么是约束呢?
约束是表级的强制规定.根据约束的作用域,约束又可分为表级约束和列级约束两种。
列级约束是指是字段定义的一部分,只能够应用在一个列上.
表级约束是指独立于列的定义,可以应用于一个表中的多个列上。
在oracle系统中定义约束时,通过constraint关键字为约束命名,如果用户没有为约束指定名称,系统会自动建立默认的名称。
总结:
作用范围:列级约束只能作用在一个列上,而表约束可以作用在多个列上(当然表约束也可以作用在一个列上)。
定义方式:列约束必须跟在列的定义里后面,表约束不与列一起,而是单独定义。
非空(not null) 约束只能定义在列上
备注:在定义约束时,可以通过指定enable或disable关键字将约束的初始状态设置为激活或禁用状态,默认是激活状态。
定义约束的语法格式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范式(非主属性必须完全依赖于任一候选键)
用户名->用户密码,用户电话,用户邮箱,用户地址.
Stu(sname,stel,semail,saddress)
用户名—> 教师名称
教师名称—>用户名
stear(sid,tname,sname)
教师名称—>教师性别,教师职务,教师年龄
Teacher(tname,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;
分享到:
相关推荐
八、性能优化 Oracle数据库性能优化是关键技能,包括索引的合理使用、SQL查询优化、数据库设计优化、分区策略、物化视图、存储过程的优化等。了解EXPLAIN PLAN、V$视图、SQL Profiler等工具对诊断和解决性能问题至关...
Oracle 学习总结 Oracle 是一种关系数据库管理系统,由 Larry Ellison 和 Bob Miner 于 1977 年创立。它是一种对象关系数据库管理系统,支持多种编程语言,包括 Java、Python、C++ 等。 一、创建 Oracle 数据库...
八、ORACLE 表与视图的管理 表与视图的管理是指对表和视图的创建、修改、删除等操作。在 Oracle 数据库中,可以使用 CREATE、ALTER、DROP 等语句来实现表和视图的管理。 Oracle 数据库学习总结资料.pdf 是一份全面...
八、自动优化器 Oracle的自动优化器可以根据统计信息自动选择最佳执行路径。定期更新统计信息,确保优化器做出正确的决策。 九、实时监控与调优 持续监控数据库性能,使用AWR、ASH(Active Session History)等工具...
以上就是对Oracle数据库常用优化方法的总结,每一种方法都需要根据实际环境进行细致的分析和实践,才能找到最适合的优化策略。在日常运维中,我们应持续学习和探索,以应对不断变化的业务需求和挑战。
八、如何学习Oracle数据库 九、资源简介 一、Oracle数据库概述 重点详细内容知识点总结: Oracle数据库是一种关系型数据库管理系统(RDBMS),由甲骨文公司开发,广泛用于企业级应用和大型数据中心。它支持大型数据...
### Oracle增删改查及入门及注意事项总结 #### 一、Oracle基础知识介绍 **Oracle**是一种广泛使用的数据库管理系统,提供了一系列强大的数据管理功能。对于初学者来说,掌握Oracle的基础操作至关重要。 #### 二、...
### 个人经验总结:Oracle数据库SCN号详解 #### 一、引言 在Oracle数据库管理与维护过程中,了解SCN(System Change Number)的概念及其作用至关重要。SCN是Oracle数据库内部用于跟踪数据库状态变化的一个重要机制,...
Oracle 调优总结 Oracle 调优是数据库管理员和开发人员日常工作中的一个关键部分。只有当数据库的性能达到最佳状态时,才能确保业务的顺利运行。下面总结了 Oracle 调优的一些关键点: 一、了解表结构和索引情况 ...
本资料“Oracle进阶 工作中最常用的知识点总结”深入探讨了Oracle数据库的核心概念和技术,对于想要提升Oracle技能的专业人士来说,是一份极具价值的学习资源。 一、Oracle数据库体系结构 Oracle数据库由多个组件...
### Oracle SQL性能优化技巧大总结 #### 一、选择最有效率的表名顺序 **背景**:在基于规则的优化器(RBO)中,Oracle解析器处理FROM子句中的表名是从右向左的。为了提高查询效率,需要合理安排表的顺序。 **技巧...
本文主要总结了重建Oracle索引的相关知识点。 一、重建索引的前提条件 当表上的数据频繁进行`UPDATE`和`DELETE`操作,或者执行了`ALTER TABLE ... MOVE`操作导致ROWID改变时,可能需要考虑重建索引。这些操作可能...
**6.3 数据分组总结** - **用途:** 使用GROUP BY和HAVING对数据进行高级筛选和分析。 #### 七、多表查询 **7.1 多表查询,betweenand语句** - **用途:** 同时查询多个表,并使用BETWEEN AND进行范围查询。 - *...
八、Oracle的云服务 Oracle云服务包括数据库即服务(DBaaS)、基础设施即服务(IaaS)和平台即服务(PaaS),提供了从本地部署到云端的平滑过渡方案。文档会简述Oracle云服务的优势和应用场景。 九、其他高级主题 ...
#### 八、多核CPU的License计算 针对多核CPU的情况,Oracle制定了相应的计算策略: - **UltraSparc T1处理器**:每个核心的系数为0.25 - **AMD/英特尔**:每个核心的系数为0.50 - **其他多核服务器**:每个核心的...
八、并行执行 Oracle的并行查询特性可以在多处理器系统上分发查询任务,提高处理速度。但并行度的选择需谨慎,过高可能导致争用资源,反而降低性能。 九、内存管理 内存管理涉及SGA的各个组件,如数据缓冲区、重做...
### ORACLE数据库学习总结 #### 一、数据库简介与安装 **1、Oracle与SQL Server比较的优点:** - **跨平台支持:** Oracle支持多种操作系统平台,如Windows、Linux、Unix等,而SQL Server主要支持Windows系统。这...
Oracle 连接字符串是指连接 Oracle 数据库的字符串书写方法,本文总结了多种连接 Oracle 数据库的字符串书写方法。 一、标准连接字符串 标准连接字符串是最基本的连接字符串格式,用于连接 Oracle 数据库。例如,...
#### 八、总结 通过上述步骤,可以实现在Windows 7客户端远程连接Linux服务器上的Oracle 10g数据库。这不仅涉及到网络配置、监听器配置,还需要正确配置客户端和服务端的相关文件,以确保连接的顺利进行。此外,了解...