【发布时间】:2011-05-25 21:12:55
【问题描述】:
有谁知道在 SQL Server 2000 数据库上列出打开的事务的任何方法吗?
我知道我可以在 SQL 2005(及更高版本)数据库版本上查询视图 sys.dm_tran_session_transactions,但是这在 SQL 2000 上不可用。
【问题讨论】:
标签: sql sql-server transactions sql-server-2000
有谁知道在 SQL Server 2000 数据库上列出打开的事务的任何方法吗?
我知道我可以在 SQL 2005(及更高版本)数据库版本上查询视图 sys.dm_tran_session_transactions,但是这在 SQL 2000 上不可用。
【问题讨论】:
标签: sql sql-server transactions sql-server-2000
使用这个是因为只要交易打开了多个交易,那么下面的交易就会起作用 SELECT * FROM sys.sysprocesses WHERE open_tran 0
【讨论】:
您可以通过以下查询获得所有活跃交易的信息
SELECT
trans.session_id AS [SESSION ID],
ESes.host_name AS [HOST NAME],login_name AS [Login NAME],
trans.transaction_id AS [TRANSACTION ID],
tas.name AS [TRANSACTION NAME],tas.transaction_begin_time AS [TRANSACTION
BEGIN TIME],
tds.database_id AS [DATABASE ID],DBs.name AS [DATABASE NAME]
FROM sys.dm_tran_active_transactions tas
JOIN sys.dm_tran_session_transactions trans
ON (trans.transaction_id=tas.transaction_id)
LEFT OUTER JOIN sys.dm_tran_database_transactions tds
ON (tas.transaction_id = tds.transaction_id )
LEFT OUTER JOIN sys.databases AS DBs
ON tds.database_id = DBs.database_id
LEFT OUTER JOIN sys.dm_exec_sessions AS ESes
ON trans.session_id = ESes.session_id
WHERE ESes.session_id IS NOT NULL
然后您通过下面的帮助关闭该事务 KILL 通过引用会话 ID 查询
KILL 77
【讨论】:
对于所有数据库查询 sys.sysprocesses
SELECT * FROM sys.sysprocesses WHERE open_tran = 1
对于当前数据库使用:
DBCC OPENTRAN
【讨论】:
DBCC OPENTRAN 有助于识别可能阻止日志截断的活动事务。 DBCC OPENTRAN 在指定数据库的事务日志中显示有关最旧的活动事务以及最旧的分布式和非分布式复制事务(如果有)的信息。仅当日志中存在活动事务或数据库包含复制信息时,才会显示结果。
如果日志中没有活动事务,则会显示一条信息性消息。
【讨论】: