[20170512]延迟约束问题.txt

简介: [20170512]延迟约束问题.txt --//别人问的问题,通过例子来说明: 1.环境: SCOTT@book> @ &r/ver1 PORT_STRING                    VERSION        BANNER --...

[20170512]延迟约束问题.txt

--//别人问的问题,通过例子来说明:

1.环境:
SCOTT@book> @ &r/ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx            11.2.0.4.0     Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

--//建立约束时可以deferrable initially immediate 或者 deferrable initially deferred.
--//还有一种NOT DEFERRABLE,这种跟deferrable initially immediate存在什么区别.

create table t
( a int constraint check_a check ( a > 0 ) deferrable initially immediate,
  b int constraint check_b check ( b > 0 ) deferrable initially deferred,
  c int constraint check_c check ( c > 0 ) deferrable,
  d int constraint check_d check ( d > 0 ) );

SCOTT@book> select constraint_name,deferrable,deferred from user_constraints  where table_name='T';
CONSTRAINT_NAME DEFERRABLE     DEFERRED
--------------- -------------- ---------
CHECK_A         DEFERRABLE     IMMEDIATE
CHECK_B         DEFERRABLE     DEFERRED
CHECK_C         DEFERRABLE     IMMEDIATE
CHECK_D         NOT DEFERRABLE IMMEDIATE

--//实际上其他都很好理解.就是对于字段A,D.两者情况都是立即起作用.也就是你不能这样插入数据,或者修改数据.


SCOTT@book> insert into t values (-1,2,3,4);
insert into t values (-1,2,3,4)
*
ERROR at line 1:
ORA-02290: check constraint (SCOTT.CHECK_A) violated

SCOTT@book> insert into t values (1,2,3,-4);
insert into t values (1,2,3,-4)
*
ERROR at line 1:
ORA-02290: check constraint (SCOTT.CHECK_D) violated

--//都是在dml时马上起作用.视乎两者没有什么区别.

2.实际上oracle还可以临时设置set constraints all deferred;或者set constraints all immediate;

SCOTT@book> set constraints all deferred;
Constraint set.

SCOTT@book> insert into t values (1,2,3,-4);
insert into t values (1,2,3,-4)
*
ERROR at line 1:
ORA-02290: check constraint (SCOTT.CHECK_D) violated

SCOTT@book> insert into t values (-1,2,3,4);
1 row created.

SCOTT@book> insert into t values (1,-2,3,4);
1 row created.

SCOTT@book> insert into t values (1,2,-3,4);
1 row created.

--//这样就可以看出两者的区别,设置set constraints all deferred;时仅仅对约束是DEFERRABLE有效.而对于约束NOT DEFERRABLE无效.
--//当然提交时不满足约束,肯定报错.

SCOTT@book> commit ;
commit
*
ERROR at line 1:
ORA-02091: transaction rolled back
ORA-02290: check constraint (SCOTT.CHECK_A) violated

--//临时修改set constraints all immediate;
SCOTT@book> set constraints all immediate;
Constraint set.

SCOTT@book> insert into t values (-1,2,3,4);
insert into t values (-1,2,3,4)
*
ERROR at line 1:
ORA-02290: check constraint (SCOTT.CHECK_A) violated


SCOTT@book> insert into t values (1,-2,3,4);
insert into t values (1,-2,3,4)
*
ERROR at line 1:
ORA-02290: check constraint (SCOTT.CHECK_B) violated

--//字段B插入负数也马上报错.

目录
相关文章
|
机器学习/深度学习 存储 人工智能
【中国大学生计算机大赛二等奖】智能中医-中e诊简介(一)
【中国大学生计算机大赛二等奖】智能中医-中e诊简介(一)
517 0
|
12月前
|
存储 网络协议 算法
UDP 协议和 TCP 协议
本文介绍了UDP和TCP协议的基本结构与特性。UDP协议具有简单的报文结构,包括报头和载荷,报头由源端口、目的端口、报文长度和校验和组成。UDP使用CRC校验和来检测传输错误。相比之下,TCP协议提供更可靠的传输服务,其结构复杂,包含序列号、确认序号和标志位等字段。TCP通过确认应答和超时重传来保证数据传输的可靠性,并采用三次握手建立连接,四次挥手断开连接,确保通信的稳定性和完整性。
292 1
UDP 协议和 TCP 协议
|
11月前
|
网络协议 安全 Linux
网络工具ping的使用方式
【10月更文挑战第19天】网络工具ping的使用方式
878 6
|
11月前
|
JSON 缓存 JavaScript
使用 jsDelivr 免费加速 GitHub Pages 博客的静态资源(二)
使用 jsDelivr 加速 GitHub Pages 的图片资源和动态编译的 JSON 资源。
207 2
|
11月前
|
存储 Java 编译器
Python学习三:学习python的 变量命名规则,算数、比较、逻辑、赋值运算符,输入与输出。
这篇文章是关于Python编程语言中变量命名规则、基本数据类型、算数运算符、比较运算符、逻辑运算符、赋值运算符以及格式化输出与输入的详细教程。
198 0
Python学习三:学习python的 变量命名规则,算数、比较、逻辑、赋值运算符,输入与输出。
|
小程序
Taro@3.x+Vue@3.x+TS开发微信小程序,根据系统主题展示不同样式(darkMode)
本文介绍如何在Taro项目中配置深色模式。通过在`src/app.config.ts`设置`darkmode`选项和在`theme.json`中定义主题变量,可以实现跟随系统主题的界面风格切换。
362 0
Taro@3.x+Vue@3.x+TS开发微信小程序,根据系统主题展示不同样式(darkMode)
|
XML Java Maven
Spring5入门到实战------16、Spring5新功能 --整合日志框架(Log4j2)
这篇文章是Spring5框架的入门到实战教程,介绍了Spring5的新功能——整合日志框架Log4j2,包括Spring5对日志框架的通用封装、如何在项目中引入Log4j2、编写Log4j2的XML配置文件,并通过测试类展示了如何使用Log4j2进行日志记录。
Spring5入门到实战------16、Spring5新功能 --整合日志框架(Log4j2)
|
前端开发 JavaScript
前端 CSS 经典:文字描边
前端 CSS 经典:文字描边
473 0
|
JSON JavaScript 数据格式
jwt-auth插件实现了基于JWT(JSON Web Tokens)进行认证鉴权的功能
jwt-auth插件实现了基于JWT(JSON Web Tokens)进行认证鉴权的功能
343 1
|
Java 编译器 Python
【python】考前复习,python基础语法知识点整理(上)
变量就是用来保存数据的,如果一个数据我们要经常用到,创建一个变量把这个数据保存起来,在后面使用的时候就会很方便.