Oracle数据库之约束

简介: 约束数据的完整性用于确保数据库数据遵从一定的商业和逻辑规则。在Oracle中,数据完整性可以使用约束、触发器、应用程序(过程、函数)三种实现。

约束

数据的完整性用于确保数据库数据遵从一定的商业和逻辑规则。在Oracle中,数据完整性可以使用约束、触发器、应用程序(过程、函数)三种实现。而约束易于维护并且性能最好,所以作为维护数据完整性的首选。

约束包括五种:

not null(不为空)  unique(唯一) primary key(主键) foreign key外键    check(检查)  五种。


not null(非空)

如果再列上定义了not null ,那么当插入数据时,必须为列提供数据

unique:

当定义了唯一约束后,该列值是不能重复的,但是可以为null

primary  key:

用于唯一的标示表行的数据,当定义主键约束后,该列不但不能重复而且不能为null【一张表最多只能有一个主键,但是可以有多个unique约束】

foreign key:

用于定义主表和从表之间的关系。外键约束要定义在从表上,主表则必须具有主键约束或是unique约束,当定义外键约束后,要求外键列数据必须在主表的主键列存在或是null

check:

用于强制行数据必须满足的条件,假定在sal列上定义了check约束,并要求列值在100~200之间如果不在此范围就会提示出错!

例子:图1

 SQL> create table goods(goodsId char(8) primary key ,goodsName  varchar2(30),unitprice number(10,2) check(unitprice >0),category  varchar(8),provider  varchar2(40));


 SQL> create table customer(customerId  char(20)  primary key,
   name varchar2(30)  not null,--非空
   address  varchar2(50),
   email varchar2(40)  unique,
   sex char(2)   default '男'  check(sex in ('男','女')),
   cardId char(18)
   );


 
SQL> create table purchase(customerId char(8) references  customer(customerId),
   goodsId char(8) references goods(goodsid),
  nums  number(10)  check(nums between 1 and 30));


图2图2


(2增加商品名不为空

SQL> alter table   goods modify  goodsName   not null;

(3)增加身份证也不能重复

SQL> alter table purchase modify nums unique;

(4)增加客户住址只能是海定,朝阳,东城,西城,通州,崇文!

SQL> alter table  customer add   constraint    customerAdd  varchar2(40)check(customerAdd in('海定','崇明','朝阳','东城','西城','通州'));


删除约束:

当不再需要某个约束时,可以删除。

alter table  表明   drop   constraint   名称;


在删除主键约束的时候,可能有错误,比如alter  table  表明  drop  primary  key ;这是因为在俩张表存在主从关系,那么删除主表的主键约束时,必须带上cascade选项;

alter table  表明 drop  primary key   cascade; 



显示约束信息:

1.显示约束信息

通过查数据字典视图user_constraints,可以显示当前用户所有的约束信息。

select   constraints_name ,constraint_type,status ,  validated  from   user_constraints  where  table_name="表明";

2.显示约束列

查询数据字典user_cons_columns,可以显示约束所对应的表列信息

select  column_name ,position  from  user_cons_columns  where   constraint_name="约束名";

图3图3

相关文章
|
20天前
|
Oracle 关系型数据库 Linux
【赵渝强老师】Oracle数据库配置助手:DBCA
Oracle数据库配置助手(DBCA)是用于创建和配置Oracle数据库的工具,支持图形界面和静默执行模式。本文介绍了使用DBCA在Linux环境下创建数据库的完整步骤,包括选择数据库操作类型、配置存储与网络选项、设置管理密码等,并提供了界面截图与视频讲解,帮助用户快速掌握数据库创建流程。
201 93
|
3月前
|
存储 Oracle 关系型数据库
服务器数据恢复—光纤存储上oracle数据库数据恢复案例
一台光纤服务器存储上有16块FC硬盘,上层部署了Oracle数据库。服务器存储前面板2个硬盘指示灯显示异常,存储映射到linux操作系统上的卷挂载不上,业务中断。 通过storage manager查看存储状态,发现逻辑卷状态失败。再查看物理磁盘状态,发现其中一块盘报告“警告”,硬盘指示灯显示异常的2块盘报告“失败”。 将当前存储的完整日志状态备份下来,解析备份出来的存储日志并获得了关于逻辑卷结构的部分信息。
|
1月前
|
SQL Oracle 关系型数据库
Oracle数据库创建表空间和索引的SQL语法示例
以上SQL语法提供了一种标准方式去组织Oracle数据库内部结构,并且通过合理使用可以显著改善查询速度及整体性能。需要注意,在实际应用过程当中应该根据具体业务需求、系统资源状况以及预期目标去合理规划并调整参数设置以达到最佳效果。
107 8
|
2月前
|
存储 安全 关系型数据库
MySQL数据库约束条件概述及其重要性讨论。
正确地实现并管理好各类紧缩条件将直接影响到企业信息管理水平与服务质量,在当今大数据背景下更显得格外重要;任何设计师都需要深刻理解其原理与运作机晰承担起责任使得所托管资料安全稳固同时又具备良好伸缩灵活度迎合日益复杂商务需求变动.
100 11
|
3月前
|
SQL Oracle 关系型数据库
比较MySQL和Oracle数据库系统,特别是在进行分页查询的方法上的不同
两者的性能差异将取决于数据量大小、索引优化、查询设计以及具体版本的数据库服务器。考虑硬件资源、数据库设计和具体需求对于实现优化的分页查询至关重要。开发者和数据库管理员需要根据自身使用的具体数据库系统版本和环境,选择最合适的分页机制,并进行必要的性能调优来满足应用需求。
132 11
|
3月前
|
Oracle 关系型数据库 数据库
数据库数据恢复—服务器异常断电导致Oracle数据库报错的数据恢复案例
Oracle数据库故障: 某公司一台服务器上部署Oracle数据库。服务器意外断电导致数据库报错,报错内容为“system01.dbf需要更多的恢复来保持一致性”。该Oracle数据库没有备份,仅有一些断断续续的归档日志。 Oracle数据库恢复流程: 1、检测数据库故障情况; 2、尝试挂起并修复数据库; 3、解析数据库文件; 4、导出并验证恢复的数据库文件。
|
监控 Oracle 关系型数据库
"深度剖析:Oracle SGA大小调整策略——从组件解析到动态优化,打造高效数据库性能"
【8月更文挑战第9天】在Oracle数据库性能优化中,系统全局区(SGA)的大小调整至关重要。SGA作为一组共享内存区域,直接影响数据库处理能力和响应速度。本文通过问答形式介绍SGA调整策略:包括SGA的组成(如数据缓冲区、共享池等),如何根据负载与物理内存确定初始大小,手动调整SGA的方法(如使用`ALTER SYSTEM`命令),以及利用自动内存管理(AMM)特性实现智能调整。调整过程中需注意监控与测试,确保稳定性和性能。
903 2
|
存储 缓存 Oracle
Oracle数据库可扩展性和性能
【7月更文挑战第6天】
292 7
|
存储 SQL 负载均衡
达梦数据库与Oracle数据库:功能、性能和适用场景对比
数据库在现代信息技术领域中扮演着至关重要的角色。在企业级应用中,选择正确的数据库管理系统对于数据存储、处理和查询效率至关重要。本文将对比两个备受关注的数据库管理系统——达梦数据库和Oracle数据库,从功能、性能和适用场景等方面进行深入探讨,以帮助读者在选择合适数据库时做出明智的决策。
3604 1

热门文章

最新文章

推荐镜像

更多