表的约束
定义:表的约束是 ORACLE 数据库中应用在表数据上的一系列强制性规则

按照约束用途分类:

  PRIMARY KEY:主键约束

  FOREIGN KEY:外键约束

  CHECK:检查约束

  UNIQUE:唯一约束

  NOT NULL:非空约束

创建约束:

--给已创建好的表添加约束
--语法结构:ALTER TABLE 表名 ADD CONSTRAINT 约束名 约束内容;

约束的添加:

  约束可以在创建表的时候添加,也可以在表创建之后添加;

  在创建表时添加约束,系统会自动分配约束名称,在表创建之后添加约束,需要手动设置约束名称。

--约束也可以在创建表的时候添加
CREATE TABLE TEST_0916(
SNO NUMBER PRIMARY KEY,
SNAME VARCHAR2(100) UNIQUE,
SBIRTHDAY DATE NOT NULL,
SSEX VARCHAR2(10) CHECK(SSEX = '男' OR SSEX = '女'),
CLASS VARCHAR2(10),
SSAL NUMBER CHECK(SSAL >= 800 AND SSAL <= 5000)
);

主键约束:该字段非空,且唯一

--语法结构:ALTER TABLE 表名 ADD CONSTRAINT 约束名 PRIMARY KEY(字段名);

--给STUDENT表中的SNO字段添加主键约束
ALTER TABLE STUDENT ADD CONSTRAINT PK_STUDENT PRIMARY KEY(SNO); INSERT INTO STUDENT(SNO) VALUES('101');
INSERT INTO STUDENT(SNO) VALUES(NULL); --该条数据插入失败,主键不能为NULL
INSERT INTO STUDENT(SNO) VALUES('102');

删除约束

--语法结构:ALTER TABLE 表名 DROP CONSTRAINT 约束名;
ALTER TABLE STUDENT DROP CONSTRAINT PK_STUDENT;

复合主键/联合主键:由多个字段一起组合的主键

--创建复合主键、联合主键
ALTER TABLE STUDENT ADD CONSTRAINT PK_STUDENT PRIMARY KEY(SNO,SNAME); INSERT INTO STUDENT(SNO,SNAME) VALUES('101',NULL); --插入失败,主键不能为NULL
INSERT INTO STUDENT(SNO,SNAME) VALUES('101','李军');
INSERT INTO STUDENT(SNO,SNAME) VALUES('101','张三');
INSERT INTO STUDENT(SNO,SNAME) VALUES('102','张三');

外键约束:必须建立在另外一张表的主键字段上

--语法结构:ALTER TABLE 表名 ADD CONSTRAINT 约束名 FOREIGN KEY(字段名) REFERENCES 从表名(字段名);

--给EMP_BAK的EMPNO字段添加外键约束,依赖于EMP表的EMPNO字段
ALTER TABLE EMP_BAK ADD CONSTRAINT FK_EMPNO FOREIGN KEY(EMPNO) REFERENCES EMP(EMPNO);

非空约束:类似于主键约束,主键约束是非空且唯一,非空约束可以不唯一(允许重复),但是不能为null

--语法结构:ALTER TABLE 表名 MODIFY 字段名 NOT NULL;

--给STUDENT表的SSEX字段添加非空约束
ALTER TABLE STUDENT MODIFY SSEX NOT NULL; INSERT INTO STUDENT (SNO, SNAME, SSEX) VALUES('101','张三','男');

检查约束

--语法结构:ALTER TABLE 表名 ADD CONSTRAINT 约束名 CHECK(筛选条件);
--给STUDENT表的SSEX字段添加检查约束,只允许插入'男'或者'女'
ALTER TABLE STUDENT ADD CONSTRAINT CHK_SSEX CHECK(SSEX = '男' OR SSEX = '女'); --添加检查约束的字段,插入只能插约束内的筛选条件,或者不插入(NULL)
INSERT INTO STUDENT (SNO, SNAME, SSEX) VALUES('102','张三',NULL);

唯一约束

--语法结构:ALTER TABLE 表名 ADD CONSTRAINT 约束名 UNIQUE(字段名);
--给STUDENT表中的SBIRTHDAY字段添加唯一约束
ALTER TABLE STUDENT ADD CONSTRAINT UNQ_STUDENT UNIQUE(SBIRTHDAY);

总结:

(1) 一张表只有一个主键,主键非空且唯一;
(2)外键只能依赖于另一张表的主键, 且两者的数据类型必须一致;
(3)约束不能修改,只能删除重建;
(4)约束也可以在创建表的时候添加。

Oracle表的约束的更多相关文章

  1. Oracle表级约束和列级约束

    Oracle表级约束和列级约束 1. 表级定义约束 指的是在定义完一个表所有列之后,再去定义所有相关的约束. 注意:not null 约束只能在列级上定义. 2. 列级定义约束 指的是在定义一个表的每 ...

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

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

  3. Oracle 表管理 约束 索引

    表的约束与完整性: 1.实体完整性 主键唯一性 2.域完整性 不能向number中插入varchar 3.参照完整性 外键 以别的表的字段作为外键,再插入该表时所插入外键的值必须在被参照表中该字段有那 ...

  4. Oracle表与约束关系

    手动回收表的存储方式: SQL> alter table aux_emp deallocate unused; //回收所有未使用的存储空间 表已更改. 回收aux_emp的存储空间,保留50K ...

  5. Oracle表名、列名、约束名的长度限制

    Oracle数据库版本11.2.0.1.0 Oracle表名.列名.约束名的长度限制 1.查询用户所有的表 select * from USER_TABLES; 2.查询用户所有表的列 select ...

  6. oracle 表迁移方法 (二) 约束不失效

    DB:11.2.0.3.0 在oracle 表迁移方法 (一)中,只是move了一张普通的表,如果表的字段带有主键约束呢 ? [oracle@db01 ~]$ sqlplus / as sysdba ...

  7. Oracle 关于定义约束 / 修改表结构 /修改约束

    ---约束分5种:主键 外键 唯一 非空 检查5类约束 Oracle中分列级别约束 与 表级别约束 列级别约束:在创建表时再列上面加约束 例如: create table table11( stuno ...

  8. Oracle day05 建表_约束

    表的创建 标准的建表语法 : CREATE TABLE [schema.] table (column datatype [DEFAULT expr], ... ); 使用子查询创建表的语法 CREA ...

  9. oracle中,约束、表名、Index等的名称长度限制最大只能30个字符

    oracle中,约束.表名.Index等的名称长度限制最大只能30个字符

随机推荐

  1. Redis数据库各种数据结构的内部实现。

    Redis数据库是一种非关系型数据库,基于key/value对,运行时加载到内存,对value支持虚拟内存, 支持多种数据结构,支持持久化,以性能著称,可用于存储,缓存,消息队列等场景.主要介绍下Re ...

  2. python 小兵(2)

    while 条件: 结构体 if=条件: 等于 while 条件: 结构体 else: print(int(Ture))    1 print(int(False))   0 切片顾头不顾尾 prin ...

  3. 微服务架构 | 7.2 构建使用 JWT 令牌存储的 OAuth2 安全认证

    目录 前言 1. JWT 令牌存储基础知识 1.1 JSON Web Token 2. 构建使用 JWT 令牌存储的 OAuth2 服务器 2.1 引入 pom.xml 依赖文件 2.2 创建 JWT ...

  4. ARC-124 部分题解

    E 直接统计原式不好做,注意到首先我们应该知道怎样的 \(x\) 序列是合法的,那么不妨首先来统计一下合法的 \(x\) 序列数量. 令 \(b_i\) 为 \(i\) 向右给的球数,那么有(\(i ...

  5. 对线面试官,凭借nginx能一战封神吗?

    面试官:小伙子,你对nginx熟悉吗? 我:当然熟悉了,请听我慢慢道来. 心里想,我能吊打面试官吗?今天非得灭一灭面试官的威风,平时都被怼的狗血淋头. 面试官:就你那点花花肠子,咱还不清楚. 我:.. ...

  6. Spring事物

    简介 Spring并不直接管理事务,而是提供了多种事务管理器,他们将事务管理的职责委托给Hibernate或者JTA等持久化机制所提供的相关平台框架的事务来实现. Spring事务管理器的接口是org ...

  7. 部分文件的MIMEType

    类型 文件拓展名 MIMEType 图片 png image/png bmp\dib image/bmp jpe\jpeg\jpg image/jpeg gif image/gif 多媒体 mp3 a ...

  8. Mac和Linux远程连接服务器异常修复(WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!)

    感谢大佬:https://blog.csdn.net/wd2014610/article/details/79945424 一.今天在使用SSH,连接远程服务器的时候,刚开始是没问题的. 后来阿里云主 ...

  9. Linux 打包压缩、软链接、硬链接、配置镜像源

    tar命令:tar -cvf 打包文件.tar  被打包文件的路径   把文件打包成tar包,但并未被压缩: [root@Server-n93yom test]# ll total 0 -rw-r-- ...

  10. Foundation框架介绍

    1.Foundation框架介绍 什么是框架? 众多功能\API的集合 框架是由许多类.方法.函数.文档按照一定的逻辑组织起来的集合,以便使研发程序变得更容易,在OS X下的Mac操作系统中大约有80 ...