自我总结,欢迎怕转!

约束的作用不多说了,直接看怎么用吧。

非空约束:
  在创建表时设置非空约束:
    CREATE TABLE table_name( column_name datatype NOT NULL)
  在修改表时添加非空约束:
    ALTER TABLE table_name MODIFY column_name datatype NOT NULL
  在修改表时去除非空约束:
    ALTER TABLE table_name MODIFY column_name dataypte NULL

主键约束:

  作用:确保表种每一行数据的唯一性
  在创建表时设置主键约束:
    1) CREATE TABLE table_name(column_name dataype PRIMARY KEY)
    2) CONSTRAINT constraint_name PRIMARY KEY(column_name1,..)
    查看约束 SELECT constraint_name FROM USER_CONSTRAINTS WHERE table_name = 'student'
  在修改表时添加主键约束:
    ALTER TABLE student ADD CONSTRAINT constraint_name PRIMARY KEY(column_name1,...)
  更改约束名称 :
    ALTER TABLE student RENAME CONSTRAINT old_name to new_name
  删除主键约束:
    暂时不用:ALTER TABLE student DISABLE|ENABLE CONSTRAINT constraint_name

    直接删除:1)ALTER TABLE student DROP CONSTRAINT constraint_name

         2) ALTER TABLE student DROP PRIMARY KEY [CASCADE]
    查看约束状态: SELECT CONSTRAINT_NAME,STATUS FROM USER_CONSTRAINTS WHERE table_name = 'student'

外键约束:
  在创建表时设置外键约束:
    1) CREATE TABLE table1 (column_name datatype REFERENCES table2(column_name))
    条件: 主表table2中的字段必须是主键
        主从表table1中的字段类型必须也主表table2中的字段类型一致
        主从表table1中字段的值必须全部来自主表table2中相应的字段,或NULL值
    2) CONSTRAINT constraint_name FOREIGN KEY(column_name ) REFERENCES table_name(column_name1) [ ON DELETE CASCADE] //级联删除 主表数据中的数据被删除时,从表中引用的字段的行数据也删除
  在修改表时设置外键约束:
    ALTER TALBLE student ADD CONSTRAINT constraint_name FOREIGN KEY(column_name) REFERENCES table2(column_name) [ ON DELETE CASCADE ]
  删除外键约束:
    暂时不用:ALTER TABLE student DISABLE | ENABLE CONSTRAINT constraint_name
    直接删除:ALTER TABLE student DROP CONSTRAINT constrain_name

唯一约束:
  主键约束与唯一性约束的区别:
    主键字段值必须为非空,唯一性约束允许有一个空值
    主键约束在每张表中只能有一个,唯一性约束在每张表中可以有多个
  在创建表时设置唯一性约束:
    1) CREATE TABLE table_name (column_name datatype UNIQUE,...)
    2) CONSTRAINT constraint_name UNIQUE(column_name) //该语句只能设置一个字段,要想设置其他字段必须新创建唯一性约束
  在修改表时设施唯一性约束:
    ALTER TABLE student CONSTRAINT constraint_name UNIQUE(column_name)
  删除唯一性约束:
    暂时禁用: ALTER TABLE student DISABLE |ENABLE CONSTRAINT constraint_name
    直接删除: ALTER TABLE student DORP CONSTRAINT constraint_name

检查约束:

  作用:让表中的值更有实际意义
  在创建表时设置检查约束:
    1) CREATE TALBE table_name (column_name datatype CHECK(money > 0))
    2) CONSTRAINT constraint_name CHECK(money > 0)
  在修改表时设置检查约束:
    ALTER TABLE student ADD CONSTRAINT constraint_name CHECK(money > 0)
  删除检查约束:
    暂时禁用: ALTER TABLE student DISABLE | ENABLE CONSTRAINT constrain_name
    直接删除: ALTER TABLE student DROP CONSTRIAN constraint_name

其他知识点:

  数据类型:
    字符型:
      CHAR(n):固定长度 , MAX :2000
      NCHAR(n):固定长度,按照Unicode格式存放数据的,用于存放汉字,MAX:1000
      VARCHAR2(n):可变长度, MAX : 4000
      NVARCHAR2(n): 可变长度,按照Unicode格式存放数据的 MAX: 2000
    数值型:
      NUMBER(p,s):p->有效数字 ; s > 0 小数后的位数 s < 0 最大有效数字到小数点的位数
      FLOAT(n) :用来存放二进制数据的,能够表示二进制的1~126位 ,若要若要转换成十进制 则需要乘以 0.30103
    日期型:
      DATA: 精确到秒(常用)
      TIMESTAMP:精确到小数秒
    其他类型:
      BLOB: MAX : 4G 以二进制格式存放
      CLOB: MAX : 4G 以字符串格式存放

  给表改名:

    rename old_name to new_name

  清空表:

    TRUNCATE TABLE table_name

  日期字段:

    regdate date default sysdate

  修改表字段:
    ALTER TABLE table_name modify email default '无';

  复制表数据:
    创建表时复制:

      CREATE TABLE table_new AS SELECT column1,...|* FROM table_old
      eg. CREATE TABLE TEST007 AS SELECT * FROM STUDENT;
    在添加数据是复制:

      INSET INTO table_new [(column1,...)] SELECT column1,...|* FROM table_old;
      eg. INSERT INTO STUDENT (ID,NAME) SELECT ID,NAME FROM TEST007;
        INSERT INTO STUDENT SELECT * FROM TEST007;

oracle如何操作约束的更多相关文章

  1. Oracle 数据完整性与约束机制

    为了维护数据库数据的完整性,在创建表时需要定义一些约束,Oracle中的约束类型包括:非空约束.主键约束.唯一约束.外键约束等.在对约束操作前,我们可以通过表名查询它具有的约束信息. 表约束 SELE ...

  2. Oracle—表、约束、索引、表空间、分区、序列、统计信息

    表.约束.索引.表空间.分区.序列.统计信息 一.表及其操作 1.创建表 create table 表名 ( 字段名1 字段类型 默认值 是否为空 , 字段名2 字段类型 默认值 是否为空, 字段名3 ...

  3. [转]Oracle 树操作(select…start with…connect by…prior)

    转自http://www.cnblogs.com/linjiqin/archive/2013/06/24/3152674.html Oracle 树操作(select-start with-conne ...

  4. Oracle列操作(增加列,修改列,删除列)

    Oracle列操作 增加一列: alter table emp4 add test varchar2(10); 修改一列: alter table emp4 modify test varchar2( ...

  5. 基于OCILIB的oracle数据库操作总结及自动生成Model和Dao的工具

    基于OCILIB的oracle数据库操作总结 1.       类图 2.       基类BaseOCIDao的设计与实现 BaseOCIDao.h头文件 #pragma once /* ----- ...

  6. Oracle集合操作函数:union、intersect、minus

    [转]Oracle集合操作函数:union.intersect.minus 集合操作符专门用于合并多条select 语句的结果,包括:UNION, UNION ALL, INTERSECT, MINU ...

  7. Oracle 树操作

    Oracle 树操作(select…start with…connect by…prior) oracle树查询的最重要的就是select…start with…connect by…prior语法了 ...

  8. Oracle字符串操作[转:http://www.cnblogs.com/xd502djj/archive/2010/08/11/1797577.html]

    ORACLE 字符串操作 1 字符串连接   SQL> select 'abc' || 'def' from dual; 'ABC'|------abcdef 2 小写SQL>select ...

  9. C# Oracle数据库操作类实例详解

    本文所述为C#实现的Oracle数据库操作类,可执行超多常用的Oracle数据库操作,包含了基础数据库连接.关闭连接.输出记录集.执行Sql语句,返回带分页功能的dataset .取表里字段的类型和长 ...

随机推荐

  1. form表单转换为Json数据

    最近对前端js学习有点多,如今想自己动手写点插件,后来发现,我想到的,其他人都想到了.于是做了以下笔记. 使用插件: 插件 :https://github.com/marioizquierdo/jqu ...

  2. php中的echo,json_decode,json_encode常用函数使用注意事项

    ---恢复内容开始--- 1.echo函数 echo只能输出单个字符串或者整数,不能直接输出数组.要输出多个字符串必须用分号 eg: echo可以输出字符串加变量,如果输出的数字字符串则会将对应的数字 ...

  3. OGG的孩子-有损音频编码opus

    Opus是一个有损声音编码的格式,由Xiph.Org基金会开发,之后由互联网工程任务组(IETF)进行标准化,目标用希望用单一格式包含声音和语音, 取代Speex和Vorbis,且适用于网络上低延迟的 ...

  4. jQuery实现跨域请求实例

    首先准备两个项目做测试(jsonp1,jsonp2) 一:在jsonp1中做一个用于测试的链接 def ajax(request): callbacks = request.GET.get(" ...

  5. 项目架构开发:数据访问层之UnitOfWork (补充)

    应lisansi同学回复(项目架构开发:数据访问层之UnitOfWork)要求,补上Dapper的DbContext实现 using Dapper.Contrib.Extensions; using ...

  6. 简单的面向对象(OO)练习

    学生设备管理系统: 每个学校都有很多班级,每个班级都有很多设备.(设备可以更新)每个设备都有购买价格,每种设备都有折旧率(如每年折旧10%) 按班级进行统计,指定的班级有多少的设数量? 按班级进行统计 ...

  7. [国嵌攻略][164][USB驱动程序设计]

    USB驱动模型 1.USB host controller driver(主控器驱动):为USB主控制器提供驱动程序 2.USB core(USB核心):连接USB主控制器驱动和USB设备驱动 3.U ...

  8. 从零开始学习前端JAVASCRIPT — 5、JavaScript基础BOM

    1:BOM(Browser  Object  Model)概念 window对象是BOM中所有对象的核心. 2:window属性(较少用) self:self代表自己,相当于window. windo ...

  9. 在form里面,放了四个UEditor,怎么在后台分别获取它们值

    1) 默认情况下提交到后台的表单名称是 "editorValue",在editor_config.js中可以配置,参数名为textarea. 2) 可以在容器标签(即script标 ...

  10. 百万级别QPS轻量级PHP框架Steeze介绍

    系统简介   Steeze是一个优雅.简洁而又高效的PHP开源框架,在整合了知名框架ThinkPHP和Laravel优点的同时,重写了底层架构,增强了功能实现. 支持swoole模型运行,支持容器.模 ...