约束(constraint):对创建的表的列属性、字段进行的限制。

诸如:not null/unique/primary key/foreign key/check

作用范围:

        ①列级约束仅仅能作用在一个列上

        ②表级约束能够作用在多个列上(当然表级约束也能够作用在一个列上)

定义方式:列约束必须跟在列的定义后面,表约束不与列一起,而是单独定义。

— —NOT NULL:不为空约束,仅仅能定义在列级

CREATE TABLE employees(
employee_id NUMBER(6),
--<span style="color:#FF0000;">系统命名</span>
 last_name VARCHAR2(25) <span style="color:#FF0000;">NOT NULL</span>,
salary NUMBER(8,2),
commission_pct NUMBER(2,2),
--<span style="color:#FF0000;">用户自己定义命名</span>
 hire_date DATE <span style="color:#FF0000;">CONSTRAINT emp_hire_date_nn NOT NULL</span>,

能够在PL/SQLDEV的My objects-Tables-employees-Check constraints中查看该表的约束。

— —UNIQUE:唯一约束,能够定义在表级或列级

CREATE TABLE employees(
employee_id NUMBER(6),
--<span style="color:#FF0000;">列级,系统命名唯一约束</span>
 last_name VARCHAR2(25) <span style="color:#FF0000;">UNIQUE</span>,
email VARCHAR2(25),
salary NUMBER(8,2),
commission_pct NUMBER(2,2),
hire_date DATE NOT NULL,
...
--<span style="color:#FF0000;">表级,用户自己定义命名唯一约束</span>
CONSTRAINT <span style="color:#FF0000;">emp_email_uk</span> UNIQUE(email));

— —PRIMARY KEY :主键,能够定义在表级或列级

    CREATE TABLE   departments(
department_id NUMBER(4),
department_name VARCHAR2(30) CONSTRAINT dept_name_nn NOT NULL,
manager_id NUMBER(6),
location_id NUMBER(4),
CONSTRAINT dept_id_pk <span style="color:#FF0000;">PRIMARY KEY</span>(department_id));

— —FOREIGN KEY: 外键,在表级指定子表中的列

— —REFERENCES: 标示在父表中的列

— —ON DELETE CASCADE(级联删除): 当父表中的列被删除时。子表中相相应的列也被删除

— —ON DELETE SET NULL(级联置空): 子表中对应的列置空

     constraint emp1_dept_id_fk <span style="color:#FF0000;">foreign key</span>(dept_id) <span style="color:#FF0000;">references</span> departments(department_id) <span style="color:#FF0000;">ON DELETE CASCADE</span>

— —CHECK :定义每一行必须满足的条件

..., salary	NUMBER(2)
CONSTRAINT emp_salary_min
CHECK (salary > 0),...

1.怎样定义约束---在创建表的同一时候。加入相应属性的约束

   1.1 表级约束 & 列级约束

   

create table emp1(
employee_id number(8),
salary number(8),
--<span style="color:#FF0000;">列级约束</span>
hire_date date not null,
dept_id number(8),
email varchar2(8) constraint emp1_email_uk unique,
name varchar2(8) constaint emp1_name_uu not null,
first_name varchar2(8),
--<span style="color:#FF0000;">表级约束</span>
constraint emp1_emp_id_pk primary key(employee_id),
constraint emp1_fir_name_uk unique(first_name),
--<span style="color:#FF0000;">外键约束</span>
 constraint emp1_dept_id_fk foreign key(dept_id) <span style="color:#FF0000;">references</span> departments(department_id) ON DELETE CASCADE
)

1.2 仅仅有not null 仅仅能使用列级约束。其它的约束两种方式皆可



2.加入和删除表的约束--在创建表以后。仅仅能加入和删除,不能改动

    2.1加入

    alter table emp1
add constaint emp1_sal_ck check(salary > 0)

2.1.1对于not null来讲。不用add。须要使用modify:

   

    alter table emp1
modify (salary not null)

2.2 删除

    alter table emp1
drop constaint emp1_sal_ck

2.3使某一个约束失效:此约束还存在于表中,仅仅是不起作用

    alter table emp1

    disable constraint emp1_email_uk;



    2.4使某一个约束激活:激活以后。此约束具有约束力

    alter table emp1
enable constraint emp1_email_uk;

oracle约束总结(not null/unique/primary key/foreign key/check)的更多相关文章

  1. Oracle数据库-primary key/foreign key和references关系

    主要介绍一下个人对主键(primary key).外键(foreign key).候选键(Candidate key).超键(super key).references的总结 概念: 主键:用户选择元 ...

  2. oracle primary key & foreign key

    主键:一个表中只有一个主键约束,但是一个主键约束可以由数据表中的多个列组成:primary key alter table TName add constraints pk_name PRIMARY ...

  3. Oracle primary key&foreign key

    --主键 alter table tablename1 add constraint pk_tablename1 primary key(column1);--增加数据表1的主键column1,如果是 ...

  4. [每日一题] OCP1z0-047 :2013-08-24 FLASHBACK—TABLE/PRIMARY KEY(FOREIGN KEY?)......98

    正确答案:D 根据题意如下操作: 一.创建表dept gyj@OCM> CREATE TABLE DEPT 2 (DEPTNO NUMBER(2,0), 3 DNAME VARCHAR2(14) ...

  5. [Oracle]约束(constraint)

    (一)约束的概念 在Oracle中,可以通过设置约束来防止无效数据进入表中.Oracle一共有5种约束: 主键约束(primary key) 外键约束(foreign key) 唯一性约束(uniqu ...

  6. 数据库六大约束用法:主键(primary key)、外键(foreign key)、非空(not null)、默认(default)、检查(check)、唯一(unique)

    1. 数据库有六大约束 主键(primary key) 外键(foreign key):被参照的键必须有唯一约束或是主键 非空(not null) 默认(default) 检查(check):orac ...

  7. MySQL - primary key PK unique key,key PK index

    primary key PK unique key 总结 primary key = unique + not null 主键不能为空每个字段值都不重复,unique可以为空,非空字段不重复 uniq ...

  8. Oracle 约束类型

    在Oracle中的约束类型:NOT NULLUNIQUE KeyPRIMARY KEYFOREIGN KEYCHECK create table emp--创建表格 ,注意约束( empno numb ...

  9. Oracle——约束

    NOT NULLUNIQUE PRIMARY KEYFOREIGN KEYCHECK 如果不指定约束名 ,Oracle server 自动按照 SYS_Cn 的格式指定约束名 --指定约束名 CREA ...

随机推荐

  1. log4j建立propertie后要建立log4j2.xml

    log4j.properties ### \u8BBE\u7F6E### log4j.rootLogger = debug,stdout,D,E ### \u8F93\u51FA\u4FE1\u606 ...

  2. 如何取消android studio启动时自动打开上次关闭的项目

    Androidstudio默认每次android studio启动就会自动打开上次关闭的项目,如果想要取消并让它显示此界面 只需要  

  3. GDB 学习

    通常使用gdb在Linux下调试C/C++程序,编译的时候加上-g选项(gcc -g ......).下面总结的是我自己经常使用(当然也有一些用的比较少)的gdb命令. (1)开始及退出 开始:gdb ...

  4. 【笔记JS/HTML/CSS】ubuntu环境下的sublime text2 安装 zenCoding

    刚接触web编程的时候就被老师安利了sublime text2 这个文本编辑器,后来发现它真的挺好用的,无论是windows还是ubuntu,都可以很简单地下载安装(到官网,免费哦),三分钟内就搞定了 ...

  5. Filesystem Hierarchy Standard (Unix, Linux etc)

    http://www.pathname.com/fhs/ /boot -- Static files of the boot loader Purpose: contains everything r ...

  6. KM算法(Kuhn-Munkres)

    算法理论基础: 可行顶点标号 用l(v)表示顶点v的标号,w(uv)表示边(u,v)的权,对于赋权二分图G=(X,Y),若对每条边e=xy,均有l(x)+l(y)>=w(xy),则称这个标号为G ...

  7. dwarfdump --arch=arm64 --lookup

    解析友盟错误信息重要指令: dwarfdump --arch=arm64 --lookup 0x1001edbc4 /Users/zhoujunbo/Library/Developer/Xcode/A ...

  8. 扩增子分析解读2提取barcode 质控及样品拆分 切除扩增引物

    本节课程,需要完成扩增子分析解读1质控 实验设计 双端序列合并 先看一下扩增子分析的整体流程,从下向上逐层分析 分析前准备 # 进入工作目录 cd example_PE250 上一节回顾:我们拿到了双 ...

  9. Analysis of container and Injection in Java, their history and future.

    Container: 发展历程: 2000 年的时候 FreeBSD 开发了一个类似于 chroot 的容器技术 Jails,这是最早期,也是功能最多的容器技术.Jails 英译过来是监狱的意思,这个 ...

  10. python安装外部模块Django

    Windows安装Django模块: 由于本人安装的Python版本是Python3.7,所以安装命令为:pip3 install django /pip3 install django安装过程中出现 ...