Oracle入门第四天(下)——约束
一、概述
1.分类
表级约束主要分为以下几种:
NOT NULL
UNIQUE
PRIMARY KEY
FOREIGN KEY
CHECK
2.注意事项
如果不指定约束名 ,Oracle server 自动按照 SYS_Cn 的格式指定约束名
创建和修改约束: 建表的同时 建表之后
可以在表级或列级定义约束
可以通过数据字典视图查看约束
3.建立约束的方式
列级:column [CONSTRAINT constraint_name] constraint_type,
表级:column,... [CONSTRAINT constraint_name] constraint_type (column, ...),
二、非空约束——NOT NULL
在定义表DDL时直接添加:
CREATE TABLE emp3(
id NUMBER(32) NOT NULL,
name VARCHAR2(10) CONSTRAINT emp3_name_nn NOT NULL
)
1.注意单词constraint的写法;
2.可以采用自定义命名约束(一般用 表名_列名_约束名的形式),若省略,则采用系统命名

三、唯一约束——UNIQUE
注意以下两种添加约束的写法:
CREATE TABLE emp4(
id NUMBER(32) UNIQUE,
name VARCHAR2(10),
CONSTRAINT emp4_name_uk UNIQUE(name)
)
1.唯一约束中是允许出现NULL值的
2.允许出现多个NULL值
// 建议采用给约束命名的方式进行管理约束
四、主键约束——PRIMARY KEY
根据主键的定义,主键约束自动拥有:唯一非空约束
CREATE TABLE emp5(
id NUMBER(32),
name VARCHAR2(10),
CONSTRAINT emp4_id_pk PRIMARY KEY(id)
)
// 主键用于唯一确定一条记录
五、外键约束——FOREIGN KEY
参照其他列的主键,称为外键(外键的值必须在参考列存在)
CREATE TABLE emp6(
id NUMBER(32),
name VARCHAR2(10),
CONSTRAINT emp4_id_fk FOREIGN KEY(id) REFERENCES emp5(id)
)
外键可选项:
FOREIGN KEY: 在表级指定子表中的列
REFERENCES: 标示在父表中的列
ON DELETE CASCADE(级联删除): 当父表中的列被删除时,子表中相对应的列也被删除
ON DELETE SET NULL(级联置空): 子表中相应的列置空
示例:
CREATE TABLE emp6(
id NUMBER(32),
name VARCHAR2(10),
CONSTRAINT emp4_id_fk FOREIGN KEY(id) REFERENCES emp5(id) ON DELETE CASCADE
)
六、检查约束——CHECK
定义必须满足的条件的约束
CREATE TABLE emp7(
id NUMBER(32),
name VARCHAR2(10),
CONSTRAINT emp7_id_ck CHECK(id > 1000 AND id < 2000)
)
七、约束管理
都是基于ALTER TABLE进行管理的!
1.添加约束
ALTER TABLE table
ADD [CONSTRAINT constraint] type (column);
示例:
ALTER TABLE emp7 ADD(CONSTRAINT emp7_name_pk PRIMARY KEY(name))
添加NOT NULL约束需要使用MODIFY关键字:
Alter table emp modify(empname varchar2(50) not null);
2.删除约束
ALTER TABLE employees
DROP CONSTRAINT emp_manager_fk;
// 所以说自定义命名约束便于管理
3.无效化约束
ALTER TABLE employees
DISABLE CONSTRAINT emp_emp_id_pk;
4.激活无效的约束
ALTER TABLE employees
ENABLE CONSTRAINT emp_emp_id_pk;
5.查询约束
SELECT constraint_name, constraint_type,
search_condition
FROM user_constraints
WHERE table_name = 'EMPLOYEES';
6.查询约束的列
通过数据字典视图:USER_CONS_COLUMNS,实际上,如果约束名有规范是可以直接看到的!
SELECT constraint_name, column_name
FROM user_cons_columns
WHERE table_name = 'EMPLOYEES';
Oracle入门第四天(下)——约束的更多相关文章
- Oracle入门第四天(上)——表管理与数据处理
一.常见数据库对象 1.基本对象 对应的对象英文名参考:https://docs.oracle.com/cd/B19306_01/server.102/b14220/intro.htm#sthref6 ...
- TYUT程序设计入门第四讲练习题题解--数论入门
程序设计入门第四讲练习题题解--数论入门 对于新知识点的学习,需要不断地刷题训练,才能有所收获,才能更好地消化知识点. 题组链接: 程序设计入门第四讲练习题--数论 by vjudge 题解: A. ...
- JavaMail入门第四篇 接收邮件
上一篇JavaMail入门第三篇 发送邮件中,我们学会了如何用JavaMail API提供的Transport类发送邮件,同样,JavaMail API中也提供了一些专门的类来对邮件的接收进行相关的操 ...
- Kotlin入门第四课:简单工厂模式
Kotlin基础知识的学习,请参考之前的文章: Kotlin入门第一课:从对比Java开始 Kotlin入门第二课:集合操作 Kotlin入门第三课:数据类型 初次尝试用Kotlin实现Android ...
- Oracle入门第五天(下)——数据库其他对象
一.概述 其他数据库对象 主要掌握的为序列 二.序列 1.什么是序列 序列: 可供多个用户用来产生唯一数值的数据库对象 自动提供唯一的数值 共享对象 主要用于提供主键值 将序列值装入内存可以提高访问效 ...
- Oracle入门第三天(下)——子查询
一.子查询 1.子查询语法 SELECT select_list FROM table WHERE expr operator (SELECT select_list FROM table) 示例: ...
- CTF---密码学入门第四题 困在栅栏里的凯撒
困在栅栏里的凯撒分值:10 来源: 北邮天枢战队 难度:易 参与人数:4531人 Get Flag:2124人 答题人数:2285人 解题通过率:93% 小白发现了一段很6的字符:NlEyQd{sef ...
- Linux零基础入门第四课
根据直播讲义整理的内容,从第四课开始.前三课的内容若后面有精力会一并整理进来. 文件的基本操作(上) 创建.删除.复制.移动和重命名 touch命令创建文件 语法 >$ touch file0 ...
- Oracle入门第三天(上)——多表查询与分组函数
一.多表查询 所有的连接分析,参考之前随笔:http://www.cnblogs.com/jiangbei/p/7420136.html 1.笛卡尔积 select last_name, depart ...
随机推荐
- 沉淀再出发:关于java中的AQS理解
沉淀再出发:关于java中的AQS理解 一.前言 在java中有很多锁结构都继承自AQS(AbstractQueuedSynchronizer)这个抽象类如果我们仔细了解可以发现AQS的作用是非常大的 ...
- MapReduce Design Patterns(chapter 3 (part 1))(五)
Chapter 3. Filtering Patterns 本章的模式有一个共同点:不会改变原来的记录.这种模式是找到一个数据的子集,或者更小,例如取前十条,或者很大,例如结果去重.这种过滤器模式跟前 ...
- Linux基础入门 - 3
第四节 Linux 目录结构及文件基本操作 4-1.Linux目录结构 Linux 的目录与 Windows 的目录的实现机制是完全不同的.一种不同是体现在目录与存储介质(磁盘,内存,DVD 等)的关 ...
- Linux 系统性能监控命令详解
Linux 系统性能监控命令详解 CPU MEMORY IO NETWORK LINUX进程内存占用查看方法 系统负载过重时往往会引起其它子系统的问题,比如:->大量的读入内存的IO请求(pag ...
- tcp通讯中socket套接字accept和listen的关系
今天看到一个文章,客户端的connect在服务端调用accept之前,突然想到这可以建立正常的连接么?以前从没细细的思考过listen accept connect之前的关系,带着疑问学习了一下,记录 ...
- What Shape Layers Are-CAShapeLayer
矢量图.gpu直接使用.占用内存小 What Shape Layers Are Shape layers are layers capable of defining shapes as vector ...
- 【NOI2008】假面舞会
题目描述 一年一度的假面舞会又开始了,栋栋也兴致勃勃的参加了今年的舞会. 今年的面具都是主办方特别定制的.每个参加舞会的人都可以在入场时选择一 个自己喜欢的面具.每个面具都有一个编号,主办方会把此编号 ...
- Kali-linux查看打开的端口
对一个大范围的网络或活跃的主机进行渗透测试,必须要了解这些主机上所打开的端口号.在Kali Linux中默认提供了Nmap和Zenmap两个扫描端口工具.为了访问目标系统中打开的TCP和UDP端口,本 ...
- linq项目中例子实例
在mvc项目中 var ls = (from i in gt.vendor_login join j in gt.vendor on i.vendor_id equa ...
- 基于Azure Blob冷存储的数据压缩算法测试对比分析
背景说明: 近期公司的数据增量迅速增长,存储的成本太高,需要采用生命周期进行管理,热存储中的数据或者被删除,或者备份至冷存储.但是冷备时是否要压缩,需要进行验证.Azure本身没有提供压缩的接口,只能 ...