-1

我正在尝试跨多个系统进行数据库事务(插入记录)。所以,我决定在 .net 中使用 System.Transaction 命名空间。我在两个系统上都配置了 MSDTC(但我不知道我是否配置正确)。我的事务有两个插入查询,一个将在本地系统执行。另一个,将在本地网络中的某个其他系统上执行。第一个插入查询成功,但第二个引发错误,例如: Message = "事务已被隐式或显式提交或中止。"


这是我的代码

    using (TransactionScope txSc = new TransactionScope())
    {
        //vrm = new VolatileRM();
        //vrm.SetMemberValue(3);
        try
        {
            using (SqlConnection cn = new SqlConnection(connStr1))
            {
                SqlCommand cmd = cn.CreateCommand();
                cmd.CommandText = "Insert into empdetail Values ('YYY')";
                cn.Open();
                cmd.ExecuteNonQuery();
                cn.Close();
            }
            using (SqlConnection cn = new SqlConnection(connStr))
            {
                SqlCommand cmd = cn.CreateCommand();
                cmd.CommandText = "Insert into stu Values ('23','senthil')";
                cn.Open();
                cmd.ExecuteNonQuery();
                cn.Close();
            }                    
            txSc.Complete();
        }
        catch (Exception e)
        {
            txSc.Dispose();
        }

    }
4

1 回答 1

3

首先检查 DTC 是否实际运行(在本地和远程系统上),然后尝试将 DTC 的身份验证设置为“匿名”,看看是否是权限问题。

此外,检查远程和本地计算机上的防火墙设置。

查看此常见问题解答:分布式事务协调器 (MSDTC) 和事务常见问题解答

配置 MS DTC 服务

与此 SO 问题相关:HRESULT: 0x8004D00E using TransactionScope - C#

于 2009-04-28T06:32:09.510 回答