2016-07-28 51 views
0

运行Microsoft SQL 2012标准,没有压缩,没有分区。 在Windows Server 2008 R2上运行。我的装载程序是VS C#2013,纯64位,.NET 4.5.2 我使用Dapper 1.42作为我的ORM。 我不使用提交/回滚/事务逻辑,这些只是简单的插入。C#Dapper loader in MS-SQL 2012插入时死锁

在加载器的顶部,我发出'SET RECOVERY SIMPLE'(这是为了解决这个问题)。

加载程序读取.csv,对数据进行一些处理,然后执行插入操作,这是程序最简单的形式,它只是几行代码。加载程序从不做选择。加载程序是在此服务器(测试服务器)上运行的唯一进程。加载器不是多线程的。我在insert上做了commandtimeout = 0。

我一直不停地收到'Transaction(Process ID xx)在另一个进程锁死资源上死锁,并被选为死锁牺牲品。重新运行交易“。

错误听起来很明显,它说我有2个进程在运行,其中一个是死锁。但是我在测试服务器上,我是唯一的用户,没有其他进程在运行。

我不知道如何调试。在我的'catch'语句中,我发出这条SQL命令来捕获其他运行的东西,但是每次出现错误时它都显示NOTHING正在运行。所以如果没有任何东西在运行,为什么我一直在插入时遇到死锁?

SELECT L.request_session_id AS SPID, DB_NAME(L.resource_database_id) AS DatabaseName, O.Name AS LockedObjectName, P.object_id AS LockedObjectId, L.resource_type AS LockedResource, L.request_mode AS LockType, ST.text AS SqlStatementText, ES.login_name AS LoginName, ES.host_name AS HostName, TST.is_user_transaction as IsUserTransaction, AT.name as TransactionName, CN.auth_scheme as AuthenticationMethod 
FROM sys.dm_tran_locks L 
LEFT JOIN sys.partitions P ON P.hobt_id = L.resource_associated_entity_id 
LEFT JOIN sys.objects O ON O.object_id = P.object_id 
LEFT JOIN sys.dm_exec_sessions ES ON ES.session_id = L.request_session_id 
LEFT JOIN sys.dm_tran_session_transactions TST ON ES.session_id = TST.session_id 
LEFT JOIN sys.dm_tran_active_transactions AT ON TST.transaction_id = AT.transaction_id 
LEFT JOIN sys.dm_exec_connections CN ON CN.session_id = ES.session_id 
CROSS APPLY sys.dm_exec_sql_text(CN.most_recent_sql_handle) AS ST 
WHERE DB_NAME(L.resource_database_id) = DB_NAME() 

回答

0

在我的“抓”语句,我发出SQL命令赶什么其他正在运行

发生死锁时受害人事务回滚。这将释放所有的锁,从而允许竞争的事务继续。只有后回滚完成是控制权返回给受害人会话并引发异常。到catch运行时,并发进程可能已经完成。

你想要做的是从根本上不正确。更何况,你已经来捕获死锁信息的手段:

而且,作为最后一个问题:sys.dm_exec_sessions permissions

如果用户在服务器上具有VIEW SERVER STATE权限,则用户将看到SQL Server实例上的所有正在执行的会话;否则,用户将只会看到当前会话