[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插入负数也马上报错.

目录
相关文章
|
8天前
|
SQL 存储 关系型数据库
group by语句查询如何确保保留重复数据
group by语句查询如何确保保留重复数据
12 0
|
6月前
【验证小bai】soft constraint按域约束与整体约束的差异
【验证小bai】soft constraint按域约束与整体约束的差异
|
SQL
[20180626]延迟块清除与只读表.txt
[20180626]延迟块清除与只读表.txt --//以前测试过延迟块清除与只读表空间的情况.今天测试只读表的情况. --//链接:[20150409]只读表空间与延迟块清除.
1244 0
|
索引
[20180425]为什么走索引逻辑读反而高.txt
[20180425]为什么走索引逻辑读反而高.txt --//别人问的问题,自己测试看看,开始以为array设置太小.还是通过例子说明问题. 1.环境: SCOTT@book> @ ver1 PORT_STRING                    VE...
1013 0
|
索引 关系型数据库 Oracle
[20171202]关于函数索引的状态.txt
[20171202]关于函数索引的状态.txt --//我曾经在一篇贴子提到索引可以disable吗?链接: --//http://blog.itpub.net/267265/viewspace-2123537/ --//实际上仅仅函数索引能disable,为什么呢?实际上自己以前并不搞清楚实际上这个跟oracle使用函数的特殊性有关.
1212 0
|
关系型数据库 Oracle Linux
[20170516]nvl与非NULL约束2.txt
[20170516]nvl与非NULL约束2.txt --//接着上午的测试看看COALESCE看看过滤的情况. 1.环境: SCOTT@book> @ &r/ver1 PORT_STRING                    VERSION      ...
922 0
|
SQL Oracle 关系型数据库
[20170516]nvl与非NULL约束.txt
[20170516]nvl与非NULL约束.txt --前几天做的测试http://blog.itpub.net/267265/viewspace-2137853/,实际上差异没有这个大,因为第2个多数是常量.
854 0
|
关系型数据库 索引
[20170427]唯一索引与约束注意的地方.txt
[20170427]唯一索引与约束注意的地方.txt --//昨天看书Apress.Expert.Oracle.Indexing.and.Access.Paths.Maximum.
920 0