一、概述

  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入门第四天(下)——约束的更多相关文章

  1. Oracle入门第四天(上)——表管理与数据处理

    一.常见数据库对象 1.基本对象 对应的对象英文名参考:https://docs.oracle.com/cd/B19306_01/server.102/b14220/intro.htm#sthref6 ...

  2. TYUT程序设计入门第四讲练习题题解--数论入门

    程序设计入门第四讲练习题题解--数论入门 对于新知识点的学习,需要不断地刷题训练,才能有所收获,才能更好地消化知识点. 题组链接: 程序设计入门第四讲练习题--数论 by vjudge 题解: A. ...

  3. JavaMail入门第四篇 接收邮件

    上一篇JavaMail入门第三篇 发送邮件中,我们学会了如何用JavaMail API提供的Transport类发送邮件,同样,JavaMail API中也提供了一些专门的类来对邮件的接收进行相关的操 ...

  4. Kotlin入门第四课:简单工厂模式

    Kotlin基础知识的学习,请参考之前的文章: Kotlin入门第一课:从对比Java开始 Kotlin入门第二课:集合操作 Kotlin入门第三课:数据类型 初次尝试用Kotlin实现Android ...

  5. Oracle入门第五天(下)——数据库其他对象

    一.概述 其他数据库对象 主要掌握的为序列 二.序列 1.什么是序列 序列: 可供多个用户用来产生唯一数值的数据库对象 自动提供唯一的数值 共享对象 主要用于提供主键值 将序列值装入内存可以提高访问效 ...

  6. Oracle入门第三天(下)——子查询

    一.子查询 1.子查询语法 SELECT select_list FROM table WHERE expr operator (SELECT select_list FROM table) 示例: ...

  7. CTF---密码学入门第四题 困在栅栏里的凯撒

    困在栅栏里的凯撒分值:10 来源: 北邮天枢战队 难度:易 参与人数:4531人 Get Flag:2124人 答题人数:2285人 解题通过率:93% 小白发现了一段很6的字符:NlEyQd{sef ...

  8. Linux零基础入门第四课

    根据直播讲义整理的内容,从第四课开始.前三课的内容若后面有精力会一并整理进来. 文件的基本操作(上) 创建.删除.复制.移动和重命名 touch命令创建文件 语法 >$ touch file0 ...

  9. Oracle入门第三天(上)——多表查询与分组函数

    一.多表查询 所有的连接分析,参考之前随笔:http://www.cnblogs.com/jiangbei/p/7420136.html 1.笛卡尔积 select last_name, depart ...

随机推荐

  1. phpMyAdmin提示“无法在发生错误时创建会话,请检查 PHP 或网站服务器日志,并正确配置 PHP 安装。”

    这是以前学生在使用phpwamp时遇到的一个问题(其他环境或是自己搭建时遇到此问题,解决方式同理) 其实这个问题与PHPWAMP本身无关,是电脑设置的问题,一般正常情况下不会出现这个问题. 现在把学生 ...

  2. [COGS 2066]七十和十七

    2066. 七十和十七 ★★★   输入文件:xvii.in   输出文件:xvii.out   简单对比时间限制:1 s   内存限制:256 MB [题目描述] 七十君最近爱上了排序算法,于是Ta ...

  3. 当有多个相同的DIV时,我怎么判断我点击的是哪个嘞

    链接:https://segmentfault.com/a/1190000003480973?utm_source=tuicool&utm_medium=referral 序言 这是我曾经面试 ...

  4. Python - if-else 的多种简洁写法

    本博客原文来自:http://www.cnblogs.com/xiexiaoxiao/p/7772441.html,对原作者表示感谢,此处个人转载. 1. 常用 if ... else写法 # 语法 ...

  5. 如何批量下载bing的背景图片?

    工具准备 wget(点击下载) 批处理命令(点击下载) 网友提供的接口:http://area.sinaapp.com/bingImg?daysAgo=1(1代表天数) 实现步骤 1.打开记事本,并将 ...

  6. Kali-linux免杀Payload生成工具Veil

    Veil是一款利用Metasploit框架生成相兼容的Payload工具,并且在大多数网络环境中能绕过常见的杀毒软件.本节将介绍Veil工具的安装及使用. 在Kali Linux中,默认没有安装Vei ...

  7. Hadoop 解除 NameNode is in safe mode

    运行Hadoop程序时,有时候会报以下错误: org.apache.hadoop.dfs.SafeModeException: Cannot delete /user/hadoop/input. Na ...

  8. JDK(一)JDK集合框架

    JDK中的集合框架分为两大类:Collection和Map.Collection以一组Object的形式保存元素,Map以Key-Value对的形式保存元素. 上图列出的类并不完整,只列举了平时比较常 ...

  9. ASP.NET如何批量保存动态生成的文本框?

    对于OA系统,表单签核功能必不可少.而根据公司的情况,表单自然又五花八门,所以就要求能够让用户自己建立表单并设定表单的流程.填写内容等等.我之前写过一篇文章[地址:pivot的用法(SQL SERVE ...

  10. Spotlight On Oracle安装和使用

    Spotlight On Oracle安装和使用 软件版本:Version: 5.0.1.1022 注册码:063920179532918005749 Site Message:Quest Free ...