(5)Oracle基础--约束
· 约束的作用
<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数据字典查看约束的名称.
(5)Oracle基础--约束的更多相关文章
- Oracle基础 11 约束 constraints
--主.外键约束 create table t( id int primary key); create table t1( id int references t(id)); 或者create ...
- Oracle基础了解
数据库: 关系型数据库 select * from 表名 非关系型数据库(做不到复杂查询) 以对象的形式进行存储 {"aaa":"ccc"}---键值对 ora ...
- Oracle基础学习笔记
Oracle基础学习笔记 最近找到一份实习工作,有点头疼的是,有阶段性考核,这...,实际想想看,大学期间只学过数据库原理,并没有针对某一数据库管理系统而系统的学习,这正好是一个机会,于是乎用了三天时 ...
- ORACLE| ORACLE基础语法汇总
创 ORACLE| ORACLE基础语法汇总 2018-07-18 16:47:34 YvesHe 阅读数 9141更多 分类专栏: [数据库] 版权声明:本文为博主原创文章,遵循CC 4.0 B ...
- Oracle基础知识汇总一
Oracle基础知识 以下内容为本人的学习笔记,如需要转载,请声明原文链接 https://www.cnblogs.com/lyh1024/p/16720759.html oracle工具: SQ ...
- oracle基础教程(8)oracle修改字符集
oracle基础教程(8)oracle修改字符集 1.用dba连接数据库 -->sqlplus / as sysdba 2.查看字符集 -->SELECT parameter, value ...
- 图说Oracle基础知识(一)
本文主要对Oralce数据库操作的基础知识进行一下梳理,以便进行归纳总结.适用于未使用过Oracle数据库的读者,或需要学习Oracle数据库方面的基础知识.如有不足之处,还请指正. 关于SQL介绍的 ...
- (2.10)Mysql之SQL基础——约束及主键重复处理
(2.10)Mysql之SQL基础——约束及主键重复处理 关键词:mysql约束,批量插入数据主键冲突 [1]查看索引: show index from table_name; [2]查看有约束的列: ...
- oracle基础教程oracle客户端详解
oracle基础教程oracle客户端工具详解 参考网址:http://www.oraclejsq.com/article/010100114.html 该教程介绍了oracle自带客户端sqlplu ...
随机推荐
- web札记
url中不能是#号,struts不读取#之后的字符串.
- 使用JConsole监控HBase内存状态
使用JConsole或者VisualVM等工具监控HBase状态时,需要修改HBase的配置文件,以解决随机端口问题. 文件名:hbase-env.sh export HBASE_JMX_BASE=& ...
- 2018.10.18 bzoj1185: [HNOI2007]最小矩形覆盖(旋转卡壳)
传送门 不难看出最后的矩形一定有一条边与凸包某条边重合. 因此先求出凸包,然后旋转卡壳求出当前最小矩形面积更新答案. 代码: #include<bits/stdc++.h> #define ...
- 2018.07.25 bzoj3878: [Ahoi2014&Jsoi2014]奇怪的计算器(线段树)
传送门 线段树综合. 让我想起一道叫做siano" role="presentation" style="position: relative;"&g ...
- [转]Go与C语言的互操作
Go有强烈的C背景,除了语法具有继承性外,其设计者以及其设计目标都与C语言有着千丝万缕的联系.在Go与C语言互操作(Interoperability)方面,Go更是提供了强大的支持.尤其是在Go中使用 ...
- 【Unity】2.0 第2章 Unity编辑器和基本操作
分类:Unity.C#.VS2015 创建日期:2016-03-26 本章要点: 1.掌握Unity 5.3.4编辑器视图和菜单项及其含义,这是入门的最基础部分,必须掌握. 2.了解最基本的操作,先学 ...
- S4 exercise -- 模块
写一个用户登录验证程序,文件如下1234.json {"expire_date": "2021-01-01", "id": 1234, &q ...
- Oracle实例名,服务名等概念区别与联系
数据库名.实例名.数据库域名.全局数据库名.服务名 , 这是几个令很多初学者容易混淆的概念.相信很多初学者都与我一样被标题上这些个概念搞得一头雾水.我们现在就来把它们弄个明白. 一.数据库名 什么是数 ...
- Windows 下使用 GCC
MinGw 是 Minimal GNU on Windows 的缩写,允许在 GNU/Linux 和 Windows 平台生成本地的 Windows 程序而不需要第三方运行时库.本文主要介绍 MinG ...
- pytest 常用命令行选项(二)
本文接上篇继续简介pytest常用的命令行选项. 8.-v(--verbose) 选项 使用-v/--verbose选项,输出的信息会更详细.最明显的区别就是每个文件中的每个测试用例都占一行,测试的名 ...