設置數據庫為SINGLE_USER模式,減少鎖定時間
ALTER DATABASE dbname SET SINGLE_USER WITH ROLLBACK IMMEDIATE
ALTER DATABASE dbname SET ALLOW_SNAPSHOT_ISOLATION ON
ALTER DATABASE dbname SET READ_COMMITTED_SNAPSHOT ON
ALTER DATABASE dbname SET MULTI_USER
當數據庫處於read committed隔離級別時,與Oracle數據庫中的效果相同,這時,update操作的舊數據會保存在tempdb中稱為version store的部分,在Oracle數據庫,這些舊數據會保存在undo表空間。只要事務不提交,其他連接可以看到update之前的舊數據。下面查詢中的version_store_reserved_page_count字段可以得到tempdb中version store所占的空間大小:
select * from sys.dm_db_file_space_usage
--查看數據庫的事務隔離相關參數
select name,
user_access,
user_access_desc,
snapshot_isolation_state,
snapshot_isolation_state_desc,
is_read_committed_snapshot_on
from sys.databases
--ALTER READ_COMMITTED_SNAPSHOT
ALTER DATABASE MES_WORKBECH_TD SET SINGLE_USER WITH ROLLBACK IMMEDIATE;
ALTER DATABASE MES_WORKBECH_TD SET ALLOW_SNAPSHOT_ISOLATION ON;
ALTER DATABASE MES_WORKBECH_TD SET READ_COMMITTED_SNAPSHOT ON;
ALTER DATABASE MES_WORKBECH_TD SET MULTI_USER;
alter database MES_WORKBECH_LOG SET SINGLE_USER WITH ROLLBACK IMMEDIATE;
alter database MES_WORKBECH_LOG SET ALLOW_SNAPSHOT_ISOLATION ON
alter database MES_WORKBECH_LOG SET READ_COMMITTED_SNAPSHOT ON;
alter database MES_WORKBECH_LOG SET MULTI_USER
ALTER DATABASE MES_WORKBECH_LOG SET SINGLE_USER WITH ROLLBACK IMMEDIATE;
ALTER DATABASE MES_WORKBECH_LOG SET ALLOW_SNAPSHOT_ISOLATION OFF
ALTER DATABASE MES_WORKBECH_LOG SET READ_COMMITTED_SNAPSHOT OFF;
ALTER DATABASE MES_WORKBECH_LOG SET MULTI_USER;
