博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
(六)Oracle学习笔记—— 约束
阅读量:4922 次
发布时间:2019-06-11

本文共 880 字,大约阅读时间需要 2 分钟。

1. 约束介绍

表虽然建立完成了,但是表中的数据是否合法并不能有所检查,而如果要想针对于表中的数据做一些过滤的话,则可以通过约束完成,约束的主要功能是保证表中的数据合法性

按照约束的分类,一共有五种约束:非空约束、唯一约束、主键约束、检查约束、外键约束。

1.1 使用如下命令检索某个表上的所有约束(WHERE条件中的表名和用户名要大写)

select * from all_constraints where table_name='EMP' and owner='SCOTT';

对于表中的CONSTRAINT_TYPE

C:校验约束,表

O:只读约束

P:主键约束

R:外键约束

U:唯一约束

V:校验约束,视图

1.2 定义约束的方法有两种:列级约束定义表级约束定义

以定义主键约束的方法来表现两种方法的区别

列级:

CREATE TABLE t_user(    id INT PRIMARY KEY);

表级:

CREATE TABLE t_user(    id INT ,    CONSTRAINT PK_USER_ID PRIMARY KEY (id));

这里可以看出两者最显著的差别是定义时间上的不同,而且列级约束定义不能定义约束的名称。

1.3 约束命名规范

约束名称建议自己定义一套命名规则,否则使用系统生成的约束名,很难能把它和对应的表、字段联系起来。

  •     非空约束     NN_表名_列名 
  •     唯一约束     UK_表名_列名
  •     主键约束     PK_表名
  •     外键约束     FK_表名_列名
  •     条件约束     CK_表名_列名
  •     默认约束     DF_表名_列名

如果约束名称超过32位长度,建议应该缩写表名,而不应用NN_表名_数字。不过具体视情况而定,很多时候 DF_表名_列名 这样命名,往往超出了32字符。所以有时候需要缩写表面或是采用其它规则。

2. 几种约束的介绍

 

 

转载于:https://www.cnblogs.com/zjfjava/p/7191181.html

你可能感兴趣的文章
[HDU] 1025 Constructing Roads In JGShining's Kingdom - 二分的求最大递增非连续子序列
查看>>
mysql数据库的左连接,右连接,内链接。
查看>>
logistic softmax
查看>>
函数模拟sort快排
查看>>
WPF Knowledge Points - 默认视图(DefaultView),CollectionSourceView,CollectionView的区别
查看>>
C#开源项目大全
查看>>
docker 小技巧 docker network create br-name 指定IP地址
查看>>
decode函数
查看>>
通过jvm 查看死锁
查看>>
多线程(大量密集的I/O处理);多进程(大量密集并行计算);Scrapy(异步,协程)...
查看>>
rabbitmq route
查看>>
恢复为TrustedInstaller权限
查看>>
怎样利用细碎时间达到整体学习的效果
查看>>
C# 位数组
查看>>
当递归遇到synchronized
查看>>
HDU - 2141 : Can you find it?
查看>>
bzoj1093 [ZJOI2007]最大半联通子图 缩点 + 拓扑序
查看>>
《Java并发编程的艺术》之线程池(二)
查看>>
SCP注意事项
查看>>
英国NHS
查看>>