ORACLE中约束-DEFERRABLE

今天看到了oracle的约束。提到DEFERRABLE,很新鲜,至少SQL SERVER里是没这玩意儿。

定义为可延迟(deferrable)的约束,可以指定为:
1.INITIALLY IMMEDIATE 初始化立即执行
2.INITIALLY DEFERRED    初始化延迟执行

从字面意思看,猜测是让约束延迟检查,但是一个初始化立即执行,一个初始化延迟执行。这又是什么意思? 我们动手测试一下吧

--延迟约束测试
CREATE TABLE CUST
(
    CUST_ID NUMBER(2) NOT NULL,
    CUST_NAME VARCHAR2(15)
);
SELECT * FROM CUST;
--新增初始化延迟约束
ALTER TABLE CUST
ADD CONSTRAINT CUST_ID_PK PRIMARY KEY(CUST_ID) DEFERRABLE INITIALLY DEFERRED;
                   
--插入数据测试
INSERT INTO CUST VALUES (1,'RAJ'); -- ROW 1
INSERT INTO CUST VALUES (1,'SAM'); -- ROW 2
COMMIT;
--ORA-02091: transaction rolled back
--ORA-00001: unique constraint (IIMAX.CUST_ID_PK) violated

 

我们指定了约束DEFERRED,在执行第13、14行SQL,并不会理解报错。在COMMIT的时候验证约束,报错整个事务也被ROLLBACK了。

此时呢,我们修改约束为IMMEDIATE,让它在SQL语句执行后进行验证

SET CONSTRAINT CUST_ID_PK IMMEDIATE;
INSERT INTO CUST VALUES (1,'LATA'); --ROW 3
INSERT INTO CUST VALUES (2,'KING'); --ROW 4
COMMIT;

OK,两条数据提交成功。

再来插入一条重复PK的数据试试:)

SET CONSTRAINT CUST_ID_PK IMMEDIATE;
INSERT INTO CUST VALUES (2,'IIMAX'); --ROW 5
COMMIT;

仍然是ORA-00001错误

文章同步:http://oracle.xyhui.net/post/2012-10-30/oracle-constraint-deferrable

自己动手,对概念理解的更透彻。希望有所帮助

 
posted @ 2012-10-30 14:20  xyhui  阅读(939)  评论(0编辑  收藏  举报