运行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()