Oracle_数据库表的约束
Oracle_数据库表的约束
| 完整性约束分类 | |
| 域完整性约束 | (非空not null,检查check) |
| 实体完整性约束 | (唯一unique,主键primary key) |
| 参照完整性约束 | (外键foreign key) |
| 三种完整性约束的区别 | |
| 域完整性约束:字段约束 实体完整性约束:行和行之间的约束 引用完整性约束:表和表之间的约束 |
|

实例:
|
--设计要求:
--建立一张用来存储学生信息的表
--字段包含学号、姓名、性别,年龄、入学日期、班级,email等信息
--学号是主键
--姓名不能为空
--性别默认值是男
--年龄范围18至30岁
--Email唯一 |
| 完整性约束 |
|
--完整性约束
--创建表时添加约束,也可以在修改表时添加约束
--主键约束 primary key
--联合主键(不能在列级别定义,因为一个表只允许有一个主键),只有多列同时相同的时候才算重复,多列都不允许为null
drop table stu;
create table stu(
),
sname ),
gender ),
age ),
enterdate date,
clazz ),
email ),
--constraints pk_id primary key (id)
constraints pk_id primary key (id, sname)
); |
|
--非空约束 not null, 只能在列级定义
drop table stu;
create table stu(
) primary key,
sname ) not null,
gender ),
age ),
enterdate date,
clazz ),
email ),
--constraints pk_id primary key (id)
); |
|
--唯一约束 unique
drop table stu;
create table stu(
) primary key,
sname ) not null,
gender ),
age ),
enterdate date,
clazz ),
email ),
--constraints pk_id primary key (id),
constraints uk_email unique (email)
); |
|
--检查约束 check
drop table stu;
create table stu(
) primary key,
sname ) not null,
gender ) default '男' check(gender in('男','女')),
age ) and 30),
enterdate date,
clazz ),
email ) unique
--constraints pk_id primary key (id),
--constraints uk_email unique (email),
--constraints ck_age check (age>=18 and age <=30)
);
insert,'阿三'); |
|
--外键约束 foreign key
--先有主表dept,后有依赖表emp
drop table clazz;
create table clazz(
),
cname ) not null,
constraints pk_clazz_id primary key(id)
);
insert,'JavaEE班');
insert,'Android班');
insert,'iOS班');
insert,'UI班');
drop table stu;
create table stu(
),
sname ) not null,
gender ) default '男',
age ),
enterdate date,
email ),
cid ),
constraints pk_stu_id primary key (id),
constraints ck_stu_gender check(gender in ('男','女')),
and 30),
constraints un_stu_email unique (email),
--constraints fk_stu_cid foreign key(cid) references clazz(id) on delete cascade--级联删除,将子表中相关项一起删除
constraints fk_stu_cid foreign key(cid) references clazz(id) on delete set null--级联删除,将字表对应的列设置为null
);
insert,,);
insert,,); delete;
select * from stu;
select * from clazz; drop table clazz;--表中的主键/唯一键被引用
--强制将主键删除
drop table clazz cascade constraints; |
|
--修改表的时候添加约束信息
drop table stu;
create table stu(
),
sname ) not null,
gender ) default '男',
age ),
enterdate date,
email ),
clazz )
);
alter table stu add constraints pk_stu_id primary key (id);
alter table stu add constraints ck_stu_gender check(gender in ('男','女','妖'));
alter and 30);
alter table stu add constraints un_stu_email unique (email);
alter table stu rename column clazz to cid;
alter));
alter table stu add constraints fk_stu_cid foreign key(cid) references clazz(id) on delete cascade;
--删除约束 不能修改,只能删除约束
alter table stu drop constraints ck_stu_gender; |
| sequence序列 |
|
--序列: sequence
--创建序列
create increment by 1;
--删除序列
drop sequence seq_stu_id;
--查看序列
insert into stu values (seq_stu_id.nextval, '小明1', '妖', 18,
sysdate);
select * from stu; |
| index索引 |
|
--索引: index
--创建索引
create index index_stu_sname on stu(sname);
--删除索引
drop index index_stu_sname;
select sname from student; create index index_cname on clazz(cname desc);
select cname from clazz; |
Oracle_数据库表的约束的更多相关文章
- 数据库表的约束constraints
数据库表的约束constraints 数据完整性约束 表的数据有一定的取值范围和联系,多表之间的数据有时也有一定的参照关系. 在创建表和修改表时,可通过定义约束条件来保证数据的完整性和一致性. 约束条 ...
- DDL创建数据库,表以及约束(极客时间学习笔记)
DDL DDL是DBMS的核心组件,是SQL的重要组成部分. DDL的正确性和稳定性是整个SQL发型的重要基础. DDL的基础语法及设计工具 DDL的英文是Data Definition Langua ...
- MySQL 表的约束与数据库设计
DQL 查询语句 排序 # 单列排序 * 只按某一个字段进行排序,单列排序 # 组合排序 * 同时对多个字段进行排序,如果第1个字段相等,则按照第2个字段排序,依次类推 * 语法: # 具体操作 * ...
- Oracle 数据库表中已有重复数据添加唯一键(唯一约束)
Oracle 数据库表中已有重复数据添加唯一键(唯一约束) 问题描述 以 demo 举例,模拟真实场景. 表 TEST_TABLE 有如下字段和数据:id 是主键,code 没有设置键和索引 ID C ...
- Python进阶----数据库引擎(InnoDB),表的创建,mysql的数据类型,mysql表的约束
Python进阶----数据库引擎(InnoDB),表的创建,mysql的数据类型,mysql表的约束 一丶MySQL的存储引擎 什么是存储引擎: MySQL中的数据用各种不同的技术存储在文件( ...
- 数据库之 MySQL --- 数据处理 之 表的约束与分页(七)
个人博客网:https://wushaopei.github.io/ (你想要这里多有) 1.约束 :为了保证数据的一致性和完整性,SQL规范以约束的方式对表数据进行额外的条件限制 ...
- 数据库表结构设计方法及原则(li)
数据库设计的三大范式:为了建立冗余较小.结构合理的数据库,设计数据库时必须遵循一定的规则.在关系型数据库中这种规则就称为范式.范式是符合某一种设计要求的总结.要想设计一个结构合理的关系型数据库,必须满 ...
- 数据库(SQL Server)管理数据库表~新奇之处
说到“数据库”,我总有一种莫名的感觉,在刚刚接触到的数据库中就让我似懂非懂渡过着,于是思考着.于是在冷静的时空中让我回想到了很多的知识,不知你们是怎样过来的,真心希望我的这篇数据库总结能够让我们都有一 ...
- C# 操作数据库表和数据库
<1>c#创建数据库表: private void CreatTable(string name) //创建数据库源数据表,name为表名 { con.ConnectionStr ...
随机推荐
- ogg12c_静默安装
1.上传压缩包:123010_fbo_ggs_Linux_x64_shiphome.zip 2.解压: unzip 123010_fbo_ggs_Linux_x64_shiphome.zip 3.配置 ...
- Xamarin 简单的网络请求
//try //{ // var httpReq = (HttpWebRequest)HttpWebRequest.Create(new Uri(re ...
- CSS3 radial-gradient 径向渐变属性 实现重复半圆角内边框
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAA8gAAADiCAIAAAAd73mYAAAG+ElEQVR4nO3dQQrkNhCG0TntHGGu4U ...
- Python(一)字符串用法
一.程序输出 :print 在Python2.X中,print 的用法是 : print "hello word! " 在Python3.X中,print作为函数的方式出现,用法: ...
- python基础(八)生成器,迭代器,装饰器,递归
生成器 在函数中使用yield关键字就会将一个普通的函数变成一个生成器(generator),普通的函数只能使用return来退出函数,而不执行return之后的代码.而生成器可以使用调用一个next ...
- [Spark性能调优] 源码补充 : Spark 2.1.X 中 Unified 和 Static MemoryManager
本课主题 Static MemoryManager 的源码鉴赏 Unified MemoryManager 的源码鉴赏 引言 从源码的角度了解 Spark 内存管理是怎么设计的,从而知道应该配置那个参 ...
- linux rsync服务
1.rsync介绍rsync是一个开源的,快速的,多功能的,可实现全量及增量的本地或远程数据同步备份的优秀工具,rsync软件适用于nunix/linux/windows多操作系统上运行.官方网站:h ...
- mysql安装及常见使用
mysql的安装和使用 说明:mysql是一个多线程,多用户的sql数据库,有着高性能,高可靠性,易于实用性等特点. 安装的软件链接:https://pan.baidu.com/s/1smRLkoX ...
- Spring Boot快速入门(三):依赖注入
原文地址:https://lierabbit.cn/articles/6 spring boot使用依赖注入的方式很简单,只需要给添加相应的注解即可 @Service用于标注业务层组件 @Contro ...
- windows service编程
1 基本概念 1.1windows服务简介 创建在它们自己的 Windows 会话中可长时间运行的可执行应用程序. 这些服务可以在计算机启动时自动启动,可以暂停和重新启动而且不显示任何用户界面. 1. ...