- IBM DB2 9.7 Advanced Application Developer Cookbook
- Sanjay Kumar Mohankumar Saraswatipura
- 384字
- 2021-08-20 15:42:19
Using the soft invalidation and automatic revalidation support
In the earlier versions of DB2, whenever an object was altered or dropped, an exclusive lock was applied to ensure that no user accessed the object. This locking resulted in lock-waits or the rolling back of the transaction because of the deadlocks.
How to do it...
To enable or disable soft invalidation at the instance level, use the DB2 registry variable, DB2_DDL_SOFT_INVAL
.
- To enable soft invalidation at the instance level, set the value of the
DB2_DDL_SOFT_INVAL
registry variable toON
.
db2set DB2_DDL_SOFT_INVAL=ON db2stop db2start
- To disable soft invalidation at the instance level, set the value of the
DB2_DDL_SOFT_INVAL
registry variable toOFF
.
db2set DB2_DDL_SOFT_INVAL=OFF db2stop db2start
How it works...
In DB2 9.7, we have the soft invalidation feature to avoid these lock-waits or deadlocks. Upon activating soft invalidation using the registry variable DB2_DDL_SOFT_INVAL=ON
in any transaction, the DDL operations, such as DROP TABLE, ALTER TABLE
, and DETACH
partitions on database objects will not be stuck because of a lock-wait (SQL0911N Reason Code 68)
or a deadlock (SQL0911N Reason Code 2)
while the modifying objects are being accessed by other transactions. This is because the current transaction will continue to access the original object definition while the new transaction will make use of the changed object definition of ALTER, DROP
, or DETACH
if the object being accessed is altered. During the DROP
statement, the current transaction would still see the object until the completion of the execution of the transaction and all new transactions would fail to find the dropped object. This way, DB2 9.7 improves the application concurrency for DDL statements.
The following is the list of DDL statements for which soft invalidation is supported in DB2 9.7:
CREATE OR REPLACE ALIAS
CREATE OR REPLACE FUNCTION
CREATE OR REPLACE TRIGGER
CREATE OR REPLACE VIEW
DROP ALIAS
DROP FUNCTION
DROP TRIGGER
DROP VIEW
There's more...
As discussed in the earlier recipe, DB2 9.7 supports automatic object revalidation, based on the database configuration parameter's AUTO_REVAL
setting.
Normally, the object would get revalidated whenever the application or the user accesses the invalid object, if AUTO_REVAL
is set to DEFERRED
. If we set AUTO_REVAL
to IMMEDIATE
, the objects get revalidated immediately after they become invalid.
- 微信公眾平臺與小程序開發:從零搭建整套系統
- 算法精粹:經典計算機科學問題的Java實現
- Designing Hyper-V Solutions
- 匯編語言程序設計(第2版)
- Learn WebAssembly
- Python忍者秘籍
- Python極簡講義:一本書入門數據分析與機器學習
- FFmpeg開發實戰:從零基礎到短視頻上線
- Windows Phone 8 Game Development
- 零基礎輕松學C++:青少年趣味編程(全彩版)
- C++ System Programming Cookbook
- AI自動化測試:技術原理、平臺搭建與工程實踐
- Microsoft Exchange Server 2016 PowerShell Cookbook(Fourth Edition)
- Shopify Application Development
- C/C++代碼調試的藝術(第2版)