在Oracle中的约束类型:
NOT NULL
UNIQUE Key
PRIMARY KEY
FOREIGN KEY
CHECK

create table emp--创建表格 ,注意约束
(
empno number(4) primary key,--主键约束
ename varchar2(11) not NULL,--非空约束
job1 varchar2(9),
mgr number(2) references dept(deptno), 
hiredage date default sysdate,
sal number(10,2) check(sal > 500),--check约束
comm number(9,0) default null
)

alter table emp-- 删除表的列
drop column comm
cascade constraints checkpoint 1000;--约束删除


定义约束
主码或主键约束可以定义在列或表上( PRIMARY KEY )
 CREATE TABLE   dept(
        deptno       NUMBER(2),
        dname      VARCHAR2(14),
        loc      VARCHAR2(13),
        CONSTRAINT dept_dname_uk UNIQUE (dname),定义约束
        CONSTRAINT dept_deptno_pk PRIMARY KEY(deptno));定义约束

create table dept
(
deptno number(2),
dname varchar2(14),
location varchar2(14),
CONSTRAINT dept_dname_uk UNIQUE(dname));-- 唯一约束
)

定义外键约束

CREATE TABLE emp(
      empno     NUMBER(4),
      ename    VARCHAR2(10) NOT NULL,
      job    VARCHAR2(9),
      mgr    NUMBER(4),
      hiredate    DATE,
      sal    NUMBER(7,2),
      comm    NUMBER(7,2),
     deptno    NUMBER(7,2) NOT NULL,(reference dept(deptno) )//括号中也声明其引用外键  
     CONSTRAINT emp_deptno_fk FOREIGN KEY (deptno)
     REFERENCES dept (deptno));

CHECK约束:定义表的每一行必须满足的条件(上面有check约束的例子)
CHECK表达是不允许:
引用伪列 CURRVAL, NEXTVAL, LEVEL, 和ROWNUM
调用SYSDATE, UID, USER,和USERENV函数
参照其它行的查询结果


增加约束(可以增加或删除约束但是不能修改约束)

ALTER TABLE     emp
   ADD CONSTRAINT  emp_mgr_fk(约束名)
         FOREIGN KEY(mgr) REFERENCES emp(empno);

...................................................................

ALTER TABLE      emp//删除约束
   DROP CONSTRAINT  emp_mgr_fk;

...................................................................
ALTER TABLE    dept//删除在表DEPT上的PRIMARY KEY约束并且删除在表EMP的DEPTNO列上的 FOREIGN KEY约束。
   DROP PRIMARY KEY CASCADE;


创建和管理约束:约束使能或使不能
ALTER TABLE        emp
    ENABLE CONSTRAINT    emp_empno_pk;
ALTER TABLE        emp
    DISABLE CONSTRAINT    emp_empno_pk CASCADE;


查看约束

查询表USER_CONSTRAINTS可以察看所有的约束和名称

SELECT    constraint_name, constraint_type,
  2        search_condition
  3   FROM    user_constraints
  4   WHERE    table_name = 'EMP';

Oracle 约束类型的更多相关文章

  1. [Oracle]约束(constraint)

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

  2. ORACLE约束总结

    你对ORACLE约束的了解如何?比较模糊还是相当透彻?如果你对下面几个问题了如指掌的话,恭喜你,你已经对约束掌握得比较好了,不用看这篇文章了.ORACLE的约束有啥功能作用? 有哪些类型约束(不同版本 ...

  3. 【Oracle】Oracle约束的总结

    你对ORACLE约束的了解如何?比较模糊还是相当透彻?如果你对下面几个问题了如指掌的话,恭喜你,你已经对约束掌握得比较好了,不用看这篇文章了.ORACLE的约束有啥功能作用? 有哪些类型约束(不同版本 ...

  4. 转 ORACLE约束总结

    https://www.cnblogs.com/kerrycode/archive/2012/05/13/2454614.html 你对ORACLE约束的了解如何?比较模糊还是相当透彻?如果你对下面几 ...

  5. oracle字段类型

    oracle 字段类型CHAR    固定长度字符串    最大长度2000    bytes              VARCHAR2    可变长度的字符串    最大长度4000    byt ...

  6. Oracle 日期类型timestamp(时间戳)和date类型使用

    body { font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI ...

  7. PHP中的抽象类与抽象方法/静态属性和静态方法/PHP中的单利模式(单态模式)/串行化与反串行化(序列化与反序列化)/约束类型/魔术方法小结

      前  言  OOP  学习了好久的PHP,今天来总结一下PHP中的抽象类与抽象方法/静态属性和静态方法/PHP中的单利模式(单态模式)/串行化与反串行化(序列化与反序列化). 1  PHP中的抽象 ...

  8. java Hibernate 处理 oracle xmltype类型

    网上关于如何处理oracle xmltype类型的博客很多,我现在分享的是针对具体业务来的,我在oracle数据库entity表中detail插入了一条xmltype类型的数据 xml的详细内容如下: ...

  9. oracle有三种类型的异常错误: 预定义 ( Predefined )错误里面的常见错误

    oracle有三种类型的异常错误: 预定义 ( Predefined )错误, 非预定义 ( Predefined )错误, 用户定义(User_define) 错误 预定义 ( Predefined ...

随机推荐

  1. sqlserver 自增字段修改为普通主键字段

    --增加备份字段alter Table tableName add columnNameBak bigint ; --将主键自增字段 赋值到备份字段update tableNameset column ...

  2. Eclipse设置、调优、使用

    eclipse调优 一般在不对eclipse进行相关设置的时候,使用eclipse总是会觉得启动好慢,用起来好卡,其实只要对eclipse的相关参数进行一些配置,就会有很大的改善. 加快启动速度 1. ...

  3. C#判断一个类中有无"指定名称"的方法

    C#中可以通过反射分析元数据来解决这个问题,示例代码如下: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 2 ...

  4. 二进制程序分析工具Pin在Windows系统中的安装和使用方法

    这篇日志其实很弱智,也是因为换了新电脑,实验环境不全(当然,做这个实验我是在虚拟机里,因为接下来想拿些恶意代码的数据),所以这里记录一下在Windows下怎么安装和使用Pin这个程序分析领域最常用的工 ...

  5. atprogram.exe : Atmel Studio Command Line Interface

    C:\Program Files\Atmel\Atmel Studio 6.1\atbackend\atprogram.exe No command specified.Atmel Studio Co ...

  6. cdoj 1131 男神的礼物 区间dp

    男神的礼物 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/problem/show/1131 Descr ...

  7. hdu 5258 数长方形 离散化

    数长方形 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=5258 Des ...

  8. 【转】android开源项目和框架

      特效: http://www.androidviews.net/ http://www.theultimateandroidlibrary.com/ 常用效果: 1. https://github ...

  9. Android自定义长按事件

    Android系统自带了长按事件,setOnLongClickListener即可监听.但是有时候,你不希望用系统的长按事件,比如当希望长按的时间更长一点的时候.这时候就需要自己来定义这个长按事件了. ...

  10. 三星Galaxy S4(GT-I9500)获取ROOT权限教程(转)

    http://news.candou.com/2013-05-20/453695_1.shtml 获取root权限的方法