· 约束的作用

  <1> 定义规则

  <2> 确保数据的完整性

· 约束

  <1> 非空约束

      ① 创建表时为字段添加非空约束

        CREATE TABLE table_name (

          column_name data_type NOT NULL, ... );

      ② 为已存在的表字段添加非空约束

        ALTER TABLE table_name MODIFY column_name data_type NOT NULL;

      ③ 删除已存在的表字段的非空约束

        ALTER TABLE table_name MODIFY column_name data_type  NULL;

   <2> 主键约束

      作用:  确保表中每条记录的唯一性

      设置为主键的字段必须非空,唯一,且一张表中只能有一个主键,但是一个主键也可以由多个字段组成,称为联合主键.  

      ① 创建表时设置主键约束

        CREATE TABLE table_name(

          column_name data_type PRIMARY KEY,  ...  );

        或        

         CREATE TABLE table_name(

          column_name data_type ,  ...

          CONSTRAINT constraint_name PRIMARY KEY(column_name1,column_name2....) );

        P:第二种方式设置的约束称为表级约束,可以设置联合主键.

           可以从数据字典user_constraints中查看某个表的约束信息.

      ② 在已存在的表中添加主键约束

        ALTER TABLE table_name ADD CONSTRAINT constraint_name PRIMARY KEY (column_name1,column_name2 , ...); 

        (注意: 添加主键时,必须确保此字段下的数据都是非空且唯一的)

      ③ 修改主键约束的名称

        ALTER TABLE table_name RENAME CONSTRAINT old_constraint_name TO new_constraint_name; 

      ④ 删除主键约束      

        ALTER TABLE table_name DROP CONSTRAINT constraint_name ;

        或

        ALTER TABLE table_name DROP PRIMARY KEY [CASCADE] ;        

        P: 禁用/启用 约束

        ALTER TABLE table_name DISABLE/ENABLE CONSTRAINT constraint_name ;

   <3> 外键约束

      ① 创建表时设置外键约束    

        CREATE TABLE table1 (

          column_name data_type REFERENCES table2 (column_name), ... );

        P: 一般称table1为从表,table2为主表,

        注意:  1. 设置外键时,引用的主表的字段必须是主键;

             2. 主外键必须是同一个数据类型;

             3. 外键字段的值必须来自对应的主键的值,或者为NULL; 

        或

        CREATE TABLE table1(

          column_name data_type , ...

          CONSTRAINT constraint_name FOREIGN KEY (column_name) REFERENCES table2 (column_name) [ON DELETE CASCADE] );          

      ② 在已存在的表中添加外键约束

        ALTER TABLE table1  ADD CONSTRAINT constraint_name

        FOREIGN KEY (column_name) REFERENCES table2(column_name) [ON DELETE CASCADE];

      ③ 删除外键约束

        ALTER TABLE table_name DROP CONSTRAINT constraint_name ;

   <4> 唯一约束  

      ① 唯一约束与主键约束的区别:

        1. 主键约束必须唯一且不能为NULL,唯一约束允许有一个NULL;

        2. 一张表中主键约束只能有一个,而唯一约束可以有多个;

      ② 创建表时设置唯一约束   

        CREATE TABLE table_name(

          column_name data_type UNIQUE , ... );

        或    

        CREATE TABLE table_name(

          column_name data_type , ...

          CONSTRAINT constraint_name UNIQUE(column_name));     

      ③ 在已存在的表中添加唯一约束

        ALTER TABLE table_name ADD CONSTRAINT constraint_name UNIQUE (column_name);

      ④ 删除唯一约束

          ALTER TABLE table_name DROP CONSTRAINT constraint_name ; 

   <5> 检查约束

      作用: 使表中的值更具有实际意义

      ① 创建表时设置检查约束

        CREATE TABLE table_name(

          column_name data_type CHECK(expressions), ... );

        或

        CREATE TABLE table_name(

          column_name data_type , ...

          CONSTRAINT constraint_name CHECK(expressions));

      ② 在已存在的表中添加检查约束

        ALTER TABLE table_name ADD CONSTRAINT constraint_name CHECK(expressions);

        ③ 删除检查约束

        ALTER TABLE table_name DROP CONSTRAINT constraint_name ;

· 小结

   <1> 主键约束一张表中只能有一个,但是一个主键可以由多个约束组成;

   <2> 外键约束是唯一一个涉及两个表之间的约束;

   <3> 只有非空约束只能在列级设置,不能再表级设置,且非空约束没有名称;

   <4> 可以通过user_constraints数据字典查看约束的名称.

作者:caobotao
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利。

(5)Oracle基础--约束的更多相关文章

  1. Oracle基础 11 约束 constraints

    --主.外键约束 create table t(  id int primary key); create table t1(  id int references t(id)); 或者create ...

  2. Oracle基础了解

    数据库: 关系型数据库 select * from 表名 非关系型数据库(做不到复杂查询) 以对象的形式进行存储 {"aaa":"ccc"}---键值对 ora ...

  3. Oracle基础学习笔记

    Oracle基础学习笔记 最近找到一份实习工作,有点头疼的是,有阶段性考核,这...,实际想想看,大学期间只学过数据库原理,并没有针对某一数据库管理系统而系统的学习,这正好是一个机会,于是乎用了三天时 ...

  4. ORACLE| ORACLE基础语法汇总

    创 ORACLE| ORACLE基础语法汇总 2018-07-18 16:47:34 YvesHe 阅读数 9141更多 分类专栏: [数据库]   版权声明:本文为博主原创文章,遵循CC 4.0 B ...

  5. Oracle基础知识汇总一

    Oracle基础知识 以下内容为本人的学习笔记,如需要转载,请声明原文链接   https://www.cnblogs.com/lyh1024/p/16720759.html oracle工具: SQ ...

  6. oracle基础教程(8)oracle修改字符集

    oracle基础教程(8)oracle修改字符集 1.用dba连接数据库 -->sqlplus / as sysdba 2.查看字符集 -->SELECT parameter, value ...

  7. 图说Oracle基础知识(一)

    本文主要对Oralce数据库操作的基础知识进行一下梳理,以便进行归纳总结.适用于未使用过Oracle数据库的读者,或需要学习Oracle数据库方面的基础知识.如有不足之处,还请指正. 关于SQL介绍的 ...

  8. (2.10)Mysql之SQL基础——约束及主键重复处理

    (2.10)Mysql之SQL基础——约束及主键重复处理 关键词:mysql约束,批量插入数据主键冲突 [1]查看索引: show index from table_name; [2]查看有约束的列: ...

  9. oracle基础教程oracle客户端详解

    oracle基础教程oracle客户端工具详解 参考网址:http://www.oraclejsq.com/article/010100114.html 该教程介绍了oracle自带客户端sqlplu ...

随机推荐

  1. UI设计是青春饭?今天告诉你真相!

    最近有学员来问,“我想转行学习UI设计,但是听很多人说,UI设计是吃青春饭的,互联网公司是不是只选择年轻的血液而淘汰年纪大的?”今天,我来统一回答一下. UI设计是不是青春饭? 我们先来思考一个问题: ...

  2. java读取配置文件的方法

    1. Preferences类 这个主要是设置个人喜好.它的数据一般存在系统目录或是用户目录.还可以操作注册表. 2. Properties类 保存键值对.可以指定路径. 3. commons con ...

  3. 上海第八中学 shader

    http://shiba.hpe.cn/jiaoyanzu/wuli/soft/xna.aspx?classId=4

  4. python之web开发利器

    http://docs.jinkan.org/docs/flask/ https://www.djangoproject.com/

  5. 关于多系统跨浏览器 BrowserStack 的使用

    偶然在Scott Hanselman Blogs看到一篇关于 BrowserStack 博文,对于前端多浏览器测试. 现在拥有各自内核的浏览器越来越多,各自的特性也千差万别.如果作为一个前端攻城师想要 ...

  6. Spring Boot与Logback的运用(自定义异常+AOP)

    在开发以及调试过程中,程序员对日志的需求是非常大的,出了什么问题,都要通过日志去进行排查,但是如果日志不清或者杂乱无章,则不利于维护 这边就比较详细的列举几种类型的日志,供大家参考 首先明白logba ...

  7. gj7 对象引用、可变性和垃圾回收

    7.1 python变量到底是什么 #python和java中的变量本质不一样,python的变量实质上是一个指针 int str, 便利贴 a = 1 a = "abc" #1. ...

  8. mysql报错排查总结

    mysql报错: [root@zabbix ~]# mysql ERROR 2002 (HY000): Can't connect to local MySQL server through sock ...

  9. Instantiation of bean failed; nested exception is org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [com.liuyang.JDbCTemplate.PersonDao]: No default constructor fo

    错误是说我的配置文件中没有对构造函数进行配置,所以找不到构造函数,在配置文件application.xml中加入如下句子: <bean id="personDao" clas ...

  10. python文件操作,读取,修改,合并

    # -*- coding:utf-8 -*- ''' 从11c开始提取 ''' import re import numpy as np import os year = '17A' ss=" ...