有没有办法在SQL Server 2000数据库中列出打开的事务?

Jam*_*man 94 sql sql-server transactions sql-server-2000

有谁知道在SQL Server 2000数据库中列出打开事务的任何方法?

我知道我可以查询sys.dm_tran_session_transactionsSQL 2005(及更高版本)数据库版本的视图,但这在SQL 2000上不可用.

gbn*_*gbn 138

对于所有数据库,请查询sys.sysprocesses

SELECT * FROM sys.sysprocesses WHERE open_tran = 1
Run Code Online (Sandbox Code Playgroud)

对于当前数据库使用:

DBCC OPENTRAN
Run Code Online (Sandbox Code Playgroud)


Rin*_*kan 25

您可以通过以下查询获取活动交易的所有信息

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
Run Code Online (Sandbox Code Playgroud)

它会给出以下类似的结果 在此输入图像描述

然后通过引用会话ID,通过KILL查询下面的帮助关闭该事务

KILL 77
Run Code Online (Sandbox Code Playgroud)


cod*_*ger 22

DBCC OPENTRAN有助于识别可能阻止日志截断的活动事务.DBCC OPENTRAN在指定数据库的事务日志中显示有关最早的活动事务以及最早的分布式和非分布式复制事务(如果有)的信息.仅当日志中存在活动事务或数据库包含复制信息时,才会显示结果.

如果日志中没有活动事务,则显示信息性消息.

DBCC OPENTRAN