SQL 事务管理全解析
1. 可延迟约束的管理
在 SQL 中,当执行修改数据的 SQL 语句时,有些约束不必立即应用于数据,而是可以在事务的稍后阶段,待向非空列插入值之后再应用。如果约束被定义为可延迟的,则可以在事务中使用 SET CONSTRAINTS
语句来延迟约束的应用或立即应用约束。
SET CONSTRAINTS
语句的语法如下:
SET CONSTRAINTS { ALL | <constraint names> }
{ DEFERRED | IMMEDIATE }
该语句有两组选项需要选择:
- 第一组选项用于指定受该语句影响的可延迟约束。若要应用于所有可延迟约束,可使用 ALL
关键字;否则,需列出约束名称,用逗号分隔。注意, SET CONSTRAINTS
语句中只能指定可延迟约束。
- 第二组选项用于指定是延迟应用已识别的约束( DEFERRED
)还是立即应用( IMMEDIATE
)。通常在插入或修改数据之前应延迟约束,在修改数据之后应用约束。
以下是一个示例:
-- 延迟 Constraint1 和 Constraint2
SET CONSTRAINTS Constraint1, Constraint2 DEFERRED ;
-- 应用 Constraint