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‘;

原文地址:https://www.cnblogs.com/jiangbei/p/8214588.html

时间: 2024-10-03 22:35:24

Oracle入门第四天(下)——约束的相关文章

java入门第四步之应用服务器的安装(Tomcat)【转】

首先打开myeclipse,在myeclipse菜单栏下面有两个按钮: 左边的按钮是进行项目的部署的(即将项目部署到服务器上),右边的按钮是进行服务器的启动的,如果你安装了tomcat服务器,那你就可以在右边按钮点击的下拉框中 找到对应的服务器, 下面我来介绍下Tomcat服务器的安装(也不能叫安装,就是引入下): 点击菜单栏的Window---->选择Preferences----->在左边的菜单栏中选择MyEclipse---->servers----->tomcat 然后根据

JavaMail入门第四篇 接收邮件

上一篇JavaMail入门第三篇 发送邮件中,我们学会了如何用JavaMail API提供的Transport类发送邮件,同样,JavaMail API中也提供了一些专门的类来对邮件的接收进行相关的操作,再介绍这些类之前,我们先来了解下邮件接收API的体系结构,JavaMail API中定义了一个java.mail.Store类,它用于执行邮件的接收任务,我们在程序中调用这个类中的方法可以获取邮箱中的各个邮件夹的信息.JavaMail使用Folder对象表示邮件夹,通过Folder对象的方法可以

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

一.概述 其他数据库对象 主要掌握的为序列 二.序列 1.什么是序列 序列: 可供多个用户用来产生唯一数值的数据库对象 自动提供唯一的数值 共享对象 主要用于提供主键值 将序列值装入内存可以提高访问效率 2.创建序列 CREATE SEQUENCE sequence [INCREMENT BY n] --每次增长的数值 [START WITH n] --从哪个值开始 [{MAXVALUE n | NOMAXVALUE}] [{MINVALUE n | NOMINVALUE}] [{CYCLE |

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

困在栅栏里的凯撒分值:10 来源: 北邮天枢战队 难度:易 参与人数:4531人 Get Flag:2124人 答题人数:2285人 解题通过率:93% 小白发现了一段很6的字符:NlEyQd{seft} 解题链接: 原题链接:http://www.shiyanbar.com/ctf/1867 [解题报告] 这是我入门密码学开始写的第四道题,这道题有点意思,题目标题为困在栅栏里的凯撒,说明肯定是要用到栅栏密码和凯撒密码,所以我们先对这段字符进行暴力破解,这时我们可以用到一个工具,叫CTFCrac

Linux零基础入门第四课

根据直播讲义整理的内容,从第四课开始.前三课的内容若后面有精力会一并整理进来. 文件的基本操作(上) 创建.删除.复制.移动和重命名 touch命令创建文件 语法 >$ touch file0 [file1 file2 ...] >$ touch file{0..9}.txt touch命令可以创建空文件,将文件名作为参数即可.传递多个文件名可同时创建多个文件. 若使用 file{0..9} 作为参数,将自动创建10个空文件,名字分别为file0.txt.file1.txt.....file9

DBArtist之Oracle入门第1步: 如何安装Oracle 11g

操作系统:  Windows 7 数据库   :  Oracle 11gR2 第一步: 下载Oracle安装包 Oracle官网:  https://www.oracle.com/index.html 点击Downloads栏目下的Oracle Database 11g Express Edition 然后点击左边的同意按钮: Accept License Agreement 再选择相应的版本,我这里选择的是第一个for Windows X64 第二步: 下载以后,解压压缩包,会有一个datab

3.java入门第四章

1.equals用于判断字符串是否相等 2.switch语句:(1)switch后面的小括号中必须是整型或者字符型:   (2)case后面必须是常量,如1,2+2,'a':字符要加单引号: (3)可以把功能相同的case合并: (4)default块可以出现在任意位置,也可以省略: 3.java循环语句:while.do-while.for while:先判断,后执行  do-while:先执行,后判断 for循环中循环变量初始化和循环变量变化部分,可以用','同时初始化或改变多个循环变量的值

Spring入门第四课

注入参数详解:null值和级联属性 可以使用专用的<null/>元素标签为Bean的字符串或其他对象类型的属性注入null值. 和Struts,Hiberante等框架一样,Spring支持级联属性的配置. 可以如下设置null值 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans&qu

JS笔记 入门第四

小测试: 注意:取消所有的设定可以直接使用 document.getElementById("txt").removeAttribute("style"); 这个是个神奇的东西. <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" Content="text/html; charset=utf-8" /> &