FIX: OdbcConnection 对象不会报告错误时您指定的.net Framework 2.0 中的数据源不支持一个事务隔离级别

文章翻译 文章翻译
文章编号: 917752 - 查看本文应用于的产品
展开全部 | 关闭全部

本文内容

症状

请考虑以下情形。用于在.net Framework 2.0 的 ODBC 中 Microsoft.net Framework 数据提供程序在您的应用程序中连接到数据源。然后使用 OdbcConnection 对象 BeginTransaction 方法启动事务。您指定的交易记录的数据源不支持一个事务隔离级别。在这种情况下 OdbcException 异常不会按预期的方式。但是,按预期方式使用.net Framework 1.1 时,将发生异常。

原因

之所以会出现此问题,因为 BeginTransaction 方法不会报告 ODBC 错误 (SQL_ERROR) 的 SQLSetConnectAttr 函数返回。自动提交模式是默认的事务管理模式的.net Framework 数据提供程序的 ODBC。数据提供程序只自动提交模式时,关闭事务隔离级别设置正确。 因此,如果指定了不正确的事务隔离级别,交易记录不会起作用。如果您调用 Commit 方法或 回滚 方法,它们将无效。Commit 方法和 回滚 方法不报告 ODBC 错误 (SQL_ERROR)。

解决方案

现在可以从 Microsoft 获得支持的修补程序。但是,它被用于解决本文中介绍的此问题。它仅应用于出现这一特定问题的系统。此修补程序可能还会接受进一步的测试。因此,如果此问题没有对您造成严重的影响,我们建议您等待下一个 NET Framework 2.0 Service Pack 包含此修补程序。

要立即解决此问题,请联系 Microsoft 客户支持服务以获取此修复程序。有关 Microsoft 客户支持服务电话号码和关于支持费用的信息的完整列表,请访问下面的 Microsoft 网站:
http://support.microsoft.com/contactus/?ws=support
注意 在特殊的情况中如果 Microsoft 支持专业人员确定某个特定更新才能解决您的问题,可能会被取消通常会导致支持电话的费用。将正常收取支持费用将应用于其他支持问题和不需要进行专门更新的问题。

系统必备组件

若要将此修补程序,您必须具有 Microsoft 支持您的计算机上安装了下列 Microsoft 知识库文章中的描述的文件:
916002当您试图连接到 SQL Server 2005 实例,在基于 ADO.NET 2.0 的应用程序中使用 SqlClient 类 FIX: 错误消息:"启动,因为它应提供有效事务描述符不允许新的请求"

重新启动要求

您不必在应用此修补程序后,重新启动计算机。

注册表信息

您不必更改注册表。

修补程序文件信息

此修补程序仅包含那些文件解决本文列出了该问题所必需的。此修补程序不能包含的所有文件将产品完全更新到最新版本所必需的。此修补程序的英文版具有的文件属性 (或更新的文件属性) 在下表中列出。日期和时间对这些文件列出在协调世界时 (UTC)。当您查看文件信息时,将转换为本地时间。若要 UTC 与本地时间之间的时差使用控制面板中的日期和时间项中的 时区 选项卡。

.NET 框架 2.0 32 位版本

收起该表格展开该表格
文件的名称文件版本文件大小日期时间平台
Mscordacwks.dll2.0.50727.158800,7682006 年五月 24 日14: 59x86
Mscorlib.dll2.0.50727.1584,317,1842006 年五月 24 日14: 59x86
Mscorwks.dll2.0.50727.1585,623,2962006 年五月 24 日14: 59x86
Sos.dll2.0.50727.158377,3442006 年五月 24 日14: 59x86
System.data.dll2.0.50727.1582,893,8242006 年五月 24 日14: 59x86

.NET 框架基于 2.0 x 64 的版本

收起该表格展开该表格
文件的名称文件版本文件大小日期时间平台
Mscordacwks.dll2.0.50727.1581,597,4402006 年五月 24 日06: 09x64
Mscorlib.dll2.0.50727.1583,956,7362006 年五月 24 日11: 25x64
Mscorwks.dll2.0.50727.15810,306,0482006 年五月 24 日06: 05x64
Sos.dll2.0.50727.158476,1602006 年五月 24 日06: 15x64
System.data.dll2.0.50727.1582,959,8722006 年五月 24 日11: 25x64

.NET 框架 2.0 Itanium 体系结构版本

收起该表格展开该表格
文件的名称文件版本文件大小日期时间平台
Mscordacwks.dll2.0.50727.1582,710,0162006 年五月 24 日06: 14IA 64
Mscorlib.dll2.0.50727.1583,956,7362006 年五月 24 日12: 03IA 64
Mscorwks.dll2.0.50727.15821,260,2882006 年五月 24 日06: 11IA 64
Sos.dll2.0.50727.158857,0882006 年五月 24 日06: 22IA 64
System.data.dll2.0.50727.1583,102,2082006 年五月 24 日12: 03IA 64

替代方法

要变通解决此问题,请确保使用正确的事务隔离级别。您可以将代码添加到应用程序可验证是否是正确的事务级别,还可以在代码中引发异常。

状态

Microsoft 已经确认这是在"适用于"一节中列出的 Microsoft 产品中的问题。

更多信息

有关命名 Microsoft SQL Server 更新架构的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
822499Microsoft SQL Server 软件更新程序包的新命名架构

有关软件更新术语的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
824684用于描述 Microsoft 软件更新的标准术语的说明

更多信息

此问题可能会导致数据损坏,因为您不能使用 回滚 方法。例如对于您可以指定一个不正确的交易记录级别。您预期发生数据损坏发生回滚。但是,回滚,也不会发生。因为 Commit 方法不会报告错误,因为数据可能不已经提交按预期的方式,可能会损坏数据。

重现此问题的步骤

  1. 创建一个 Microsoft Access 数据文件 (.mdb),然后创建一个包含两列的表。假定该数据文件保存在 d:\db1.mdb 文件夹中,表名为 T1。假设这两个列称为 C1 和 C2。
  2. T1 表中插入一些记录。
  3. 使用 Microsoft 可 Visual Studio 的 2005年创建 C# 项目,然后将以下代码粘贴到
    string cnstr = @"Driver={Microsoft Access Driver (*.mdb)};DBQ=d:\db1.mdb;UID=Admin;PWD=;"
    OdbcConnection cn = new OdbcConnection(cnstr);
    cn.Open();
    System.Diagnostics.Debug.WriteLine("connected.");
    
    try
    {
    OdbcTransaction trn = cn.BeginTransaction(IsolationLevel.ReadUncommitted);
    OdbcCommand cmd = new OdbcCommand("select * from T1", C1, C2);
    OdbcDataReader dr;
    dr = cmd.ExecuteReader();
    while (dr.Read())
    {
    System.Diagnostics.Debug.WriteLine(dr[1].ToString());
    }
    dr.Close();
    trn.Commit();
    }
    catch (OdbcException odbcex)
    {
    System.Diagnostics.Debug.WriteLine(odbcex.Message);
    System.Diagnostics.Debug.WriteLine(odbcex.StackTrace);
    }
    cn.Close();
    cn = null;
    
    一个方法。
  4. 运行在的应用程序,并确保被调用方法。
完成这些步骤之后,您会注意到任何异常发生。

属性

文章编号: 917752 - 最后修改: 2007年12月3日 - 修订: 3.3
这篇文章中的信息适用于:
  • Microsoft .NET Framework 2.0
关键字:?
kbmt kbprb kbtshoot kbexpertiseadvanced KB917752 KbMtzh
机器翻译
注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。
点击这里察看该文章的英文版: 917752
Microsoft和/或其各供应商对于为任何目的而在本服务器上发布的文件及有关图形所含信息的适用性,不作任何声明。 所有该等文件及有关图形均"依样"提供,而不带任何性质的保证。Microsoft和/或其各供应商特此声明,对所有与该等信息有关的保证和条件不负任何责任,该等保证和条件包括关于适销性、符合特定用途、所有权和非侵权的所有默示保证和条件。在任何情况下,在由于使用或运行本服务器上的信息所引起的或与该等使用或运行有关的诉讼中,Microsoft和/或其各供应商就因丧失使用、数据或利润所导致的任何特别的、间接的、衍生性的损害或任何因使用而丧失所导致的之损害、数据或利润不负任何责任。

提供反馈

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com