FIX: 您可以收到了不正确的值时插入数据到一个表,该表包含标识列中使用 ActiveX 数据对象的应用程序使用客户端游标后,查询最后插入的标识值

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

本文内容

症状

请考虑以下情形。
  • Microsoft SQL Server 的实例中有两个的表,每个表都包含标识列。
  • 在第一个表上创建一个 INSERT 触发器。触发器在执行时,触发器会插入到第二个表的数据。
  • 可以使用 Microsoft ActiveX 数据对象 (ADO) 连接到的 SQL Server 实例的应用程序。
  • 在该的应用程序中使用客户端光标插入到第一个表的数据。
在这种情况下运行该应用程序,然后查询最后插入的标识值时您可能会发现该函数返回了不正确的值。该值对应于而不是第二个表上第一个表上生成的自动增加值。

之所以会出现此问题,在将 Microsoft 数据访问组件 (MDAC) 2.8。您可能会遇到下面的 Windows 操作系统上安装的 MDAC 2.8:
  • Windows XP Service Pack 2 (SP2)
  • Windows XP Service Pack 3 (SP3)
  • Windows Server 2003 Service Pack 1 (SP1)
  • Windows Server 2003 Service Pack 2 (SP2)
  • Windows Vista 服务包 1 (SP1)
  • Windows 2008 Server

原因

插入触发器时在第一个表中插入数据,使用 @ @ IDENTITY 代替 SCOPE_IDENTITY 函数以获取最后插入的标识值的函数。因此,该 @ @ IDENTITY 函数可能会返回相同的表不会生成一个标识值。

解决方案

修补程序信息

可以从 Microsoft 获得支持的修补程序。但是,此修补程序被用于解决本文所述的此问题。此修补程序仅应用于出现本文所述问题的系统。此修补程序可能会接受进一步的测试。因此,如果此问题没有对您造成严重的影响,我们建议您等待包含此修补程序的下一个软件更新。

是否可供下载此修补程序没有"提供修补程序下载"部分中,在这篇知识库文章的顶部。如果不会显示此部分,请联系 Microsoft 客户服务和支持以获取此修复程序。

注意如果出现其他问题,或者如果需要进行任何故障诊断,则您可能不得不创建单独的服务请求。将正常收取支持费用将应用于其他支持问题和不需要进行此特定的修补程序的问题。有关完整列表的 Microsoft 客户服务和支持的电话号码,或创建一个单独的服务请求,请访问下面的 Microsoft 网站:
http://support.microsoft.com/contactus/?ws=support
注意"提供修补程序下载"窗体所显示的此修复程序是可用的语言。如果您看不到您的语言,则是一个修复程序不能用于该语言。

系统必备组件

您必须具有相应的 service pack 安装之前应用此修补程序。

重新启动信息

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

注册表信息

您不必更改注册表。

修补程序文件信息

此修补程序仅包含那些文件解决本文列出了该问题所必需的。此修补程序可能不包含将产品完全更新到最新版本所必需的所有文件。此修补程序的英文版具有的文件属性 (或更新的文件属性) 在下表中列出。日期和时间对这些文件列出在协调世界时 (UTC)。当您查看文件信息时,将转换为本地时间。若要 UTC 与本地时间之间的时差使用控制面板中的 日期和时间 项中的 时区 选项卡。
Windows XP SP2,32 位版本
收起该表格展开该表格
文件的名称文件版本文件大小日期时间
Msadce.dll2.81.1144.0331,7762008 年十二月 31 日14: 35
Windows XP SP3,32 位版本
收起该表格展开该表格
文件的名称文件版本文件大小日期时间
Msadce.dll2.81.3010.0331,7762008 年十二月 31 日14: 38
Windows Server 2003 SP1 32 位版本
收起该表格展开该表格
文件的名称文件版本文件大小日期时间
Msadce.dll2.82.3272.0356,3522008 年十二月 31 日16: 04
Windows Server 2003 SP1,x 基于 x64 的版本
收起该表格展开该表格
文件的名称文件版本文件大小日期时间平台
Msadce.dll2.82.3272.0622,5922008 年十二月 31 日13: 48x64
Wmsadce.dll2.82.3272.0356,3522008 年十二月 31 日13: 48x86
Windows Server 2003 SP1 基于 Itanium 的版本
收起该表格展开该表格
文件的名称文件版本文件大小日期时间平台
Msadce.dll2.82.3272.01,212,4162008 年十二月 31 日13: 48IA 64
Wmsadce.dll2.82.3272.0356,3522008 年十二月 31 日13: 48x86
Windows Server 2003 SP2 32 位版本
收起该表格展开该表格
文件的名称文件版本文件大小日期时间
Msadce.dll2.82.4437.0356,3522008 年十二月 31 日15: 55
Windows Server 2003 SP2,x 基于 x64 的版本
收起该表格展开该表格
文件的名称文件版本文件大小日期时间平台
Msadce.dll2.82.4437.0622,5922008 年十二月 31 日13: 53x64
Wmsadce.dll2.82.4437.0356,3522008 年十二月 31 日13: 53x86
Windows Server 2003 SP2 基于 Itanium 的版本
收起该表格展开该表格
文件的名称文件版本文件大小日期时间平台
Msadce.dll2.82.4437.01,212,4162008 年十二月 31 日13: 51IA 64
Wmsadce.dll2.82.4437.0356,3522008 年十二月 31 日13: 51x86
Windows Vista SP1,32 位版本
收起该表格展开该表格
文件的名称文件版本文件大小日期时间
Package_for_kb961451_client_1 ~ 31bf3856ad364e35 ~ x86 ~ ~ 6.0.2.0.mum不适用1,3672008 年十二月 31 日15: 00
Package_for_kb961451_client ~ 31bf3856ad364e35 ~ x86 ~ ~ 6.0.2.0.mum不适用1,4302008 年十二月 31 日15: 00
Package_for_kb961451_sc_0 ~ 31bf3856ad364e35 ~ x86 ~ ~ 6.0.2.0.mum不适用1,4212008 年十二月 31 日15: 00
Package_for_kb961451_sc ~ 31bf3856ad364e35 ~ x86 ~ ~ 6.0.2.0.mum不适用1,4222008 年十二月 31 日15: 00
Package_for_kb961451_server_0 ~ 31bf3856ad364e35 ~ x86 ~ ~ 6.0.2.0.mum不适用1,4252008 年十二月 31 日15: 00
Package_for_kb961451_server ~ 31bf3856ad364e35 ~ x86 ~ ~ 6.0.2.0.mum不适用1,4302008 年十二月 31 日15: 00
X86_5e4a93ecd0b53d31b4ac3789c9b5bd45_31bf3856ad364e35_6.0.6001.22342_none_2f74674e1031809b.manifest不适用7382008 年十二月 31 日15: 00
X86_microsoft-窗口-m...nts-mdac 的 rds-ce-dll_31bf3856ad364e35_6.0.6001.22342_none_6251560e5afb6c40.manifest不适用15,0012008 年十二月 31 日04: 57
Msadce.dll6.0.6001.22342454,6562008 年十二月 31 日04: 23
基于 x64 的版本的 Windows Vista SP1
收起该表格展开该表格
文件的名称文件版本文件大小日期时间平台
Amd64_493387e62613f98c9bf65441084bd917_31bf3856ad364e35_6.0.6001.22342_none_f1cd024aaf4fde26.manifest不适用1,1242008 年十二月 31 日15: 00不适用
Amd64_microsoft-窗口-m...nts-mdac 的 rds-ce-dll_31bf3856ad364e35_6.0.6001.22342_none_be6ff1921358dd76.manifest不适用14,6832008 年十二月 31 日05: 26不适用
Package_for_kb961451_client_1 ~ 31bf3856ad364e35 ~ amd64 ~ ~ 6.0.2.0.mum不适用1,3752008 年十二月 31 日15: 00不适用
Package_for_kb961451_client ~ 31bf3856ad364e35 ~ amd64 ~ ~ 6.0.2.0.mum不适用1,4382008 年十二月 31 日15: 00不适用
Package_for_kb961451_sc_0 ~ 31bf3856ad364e35 ~ amd64 ~ ~ 6.0.2.0.mum不适用1,4292008 年十二月 31 日15: 00不适用
Package_for_kb961451_sc ~ 31bf3856ad364e35 ~ amd64 ~ ~ 6.0.2.0.mum不适用1,4302008 年十二月 31 日15: 00不适用
Package_for_kb961451_server_0 ~ 31bf3856ad364e35 ~ amd64 ~ ~ 6.0.2.0.mum不适用1,4332008 年十二月 31 日15: 00不适用
Package_for_kb961451_server ~ 31bf3856ad364e35 ~ amd64 ~ ~ 6.0.2.0.mum不适用1,4382008 年十二月 31 日15: 00不适用
X86_microsoft-窗口-m...nts-mdac 的 rds-ce-dll_31bf3856ad364e35_6.0.6001.22342_none_6251560e5afb6c40.manifest不适用15,0012008 年十二月 31 日04: 57不适用
Msadce.dll6.0.6001.22342589,8242008 年十二月 31 日04: 48x64
Msadce.dll6.0.6001.22342454,6562008 年十二月 31 日04: 23x86
Windows Vista SP1,基于 Itanium 的版本
收起该表格展开该表格
文件的名称文件版本文件大小日期时间
Ia64_81d9a6114da25ea41bd90118475b77eb_31bf3856ad364e35_6.0.6001.22342_none_38746d245142eb79.manifest不适用1,1222008 年十二月 31 日15: 00
Ia64_microsoft-窗口-m...nts-mdac 的 rds-ce-dll_31bf3856ad364e35_6.0.6001.22342_none_6252fa045af9753c.manifest不适用14,6672008 年十二月 31 日05: 16
Package_for_kb961451_sc_0 ~ 31bf3856ad364e35 ~ ia64 ~ ~ 6.0.2.0.mum不适用1,4252008 年十二月 31 日15: 00
Package_for_kb961451_sc ~ 31bf3856ad364e35 ~ ia64 ~ ~ 6.0.2.0.mum不适用1,4262008 年十二月 31 日15: 00
Package_for_kb961451_server_0 ~ 31bf3856ad364e35 ~ ia64 ~ ~ 6.0.2.0.mum不适用1,4292008 年十二月 31 日15: 00
Package_for_kb961451_server ~ 31bf3856ad364e35 ~ ia64 ~ ~ 6.0.2.0.mum不适用1,4342008 年十二月 31 日15: 00
Msadce.dll6.0.6001.223421,175,5522008 年十二月 31 日04: 41
Windows Server 2008,32 位版本
收起该表格展开该表格
文件的名称文件版本文件大小日期时间
Package_for_kb961451_client_1 ~ 31bf3856ad364e35 ~ x86 ~ ~ 6.0.2.0.mum不适用1,3672008 年十二月 31 日15: 00
Package_for_kb961451_client ~ 31bf3856ad364e35 ~ x86 ~ ~ 6.0.2.0.mum不适用1,4302008 年十二月 31 日15: 00
Package_for_kb961451_sc_0 ~ 31bf3856ad364e35 ~ x86 ~ ~ 6.0.2.0.mum不适用1,4212008 年十二月 31 日15: 00
Package_for_kb961451_sc ~ 31bf3856ad364e35 ~ x86 ~ ~ 6.0.2.0.mum不适用1,4222008 年十二月 31 日15: 00
Package_for_kb961451_server_0 ~ 31bf3856ad364e35 ~ x86 ~ ~ 6.0.2.0.mum不适用1,4252008 年十二月 31 日15: 00
Package_for_kb961451_server ~ 31bf3856ad364e35 ~ x86 ~ ~ 6.0.2.0.mum不适用1,4302008 年十二月 31 日15: 00
X86_5e4a93ecd0b53d31b4ac3789c9b5bd45_31bf3856ad364e35_6.0.6001.22342_none_2f74674e1031809b.manifest不适用7382008 年十二月 31 日15: 00
X86_microsoft-窗口-m...nts-mdac 的 rds-ce-dll_31bf3856ad364e35_6.0.6001.22342_none_6251560e5afb6c40.manifest不适用15,0012008 年十二月 31 日04: 57
Msadce.dll6.0.6001.22342454,6562008 年十二月 31 日04: 23
基于 x64 的版本的 Windows Server 2008
收起该表格展开该表格
文件的名称文件版本文件大小日期时间平台
Amd64_493387e62613f98c9bf65441084bd917_31bf3856ad364e35_6.0.6001.22342_none_f1cd024aaf4fde26.manifest不适用1,1242008 年十二月 31 日15: 00不适用
Amd64_microsoft-窗口-m...nts-mdac 的 rds-ce-dll_31bf3856ad364e35_6.0.6001.22342_none_be6ff1921358dd76.manifest不适用14,6832008 年十二月 31 日05: 26不适用
Package_for_kb961451_client_1 ~ 31bf3856ad364e35 ~ amd64 ~ ~ 6.0.2.0.mum不适用1,3752008 年十二月 31 日15: 00不适用
Package_for_kb961451_client ~ 31bf3856ad364e35 ~ amd64 ~ ~ 6.0.2.0.mum不适用1,4382008 年十二月 31 日15: 00不适用
Package_for_kb961451_sc_0 ~ 31bf3856ad364e35 ~ amd64 ~ ~ 6.0.2.0.mum不适用1,4292008 年十二月 31 日15: 00不适用
Package_for_kb961451_sc ~ 31bf3856ad364e35 ~ amd64 ~ ~ 6.0.2.0.mum不适用1,4302008 年十二月 31 日15: 00不适用
Package_for_kb961451_server_0 ~ 31bf3856ad364e35 ~ amd64 ~ ~ 6.0.2.0.mum不适用1,4332008 年十二月 31 日15: 00不适用
Package_for_kb961451_server ~ 31bf3856ad364e35 ~ amd64 ~ ~ 6.0.2.0.mum不适用1,4382008 年十二月 31 日15: 00不适用
X86_microsoft-窗口-m...nts-mdac 的 rds-ce-dll_31bf3856ad364e35_6.0.6001.22342_none_6251560e5afb6c40.manifest不适用15,0012008 年十二月 31 日04: 57不适用
Msadce.dll6.0.6001.22342589,8242008 年十二月 31 日04: 48x64
Msadce.dll6.0.6001.22342454,6562008 年十二月 31 日04: 23x86
Windows Server 2008,基于 Itanium 的版本
收起该表格展开该表格
文件的名称文件版本文件大小日期时间平台
Ia64_81d9a6114da25ea41bd90118475b77eb_31bf3856ad364e35_6.0.6001.22342_none_38746d245142eb79.manifest不适用1,1222008 年十二月 31 日15: 00不适用
Ia64_microsoft-窗口-m...nts-mdac 的 rds-ce-dll_31bf3856ad364e35_6.0.6001.22342_none_6252fa045af9753c.manifest不适用14,6672008 年十二月 31 日05: 16不适用
Package_for_kb961451_sc_0 ~ 31bf3856ad364e35 ~ ia64 ~ ~ 6.0.2.0.mum不适用1,4252008 年十二月 31 日15: 00不适用
Package_for_kb961451_sc ~ 31bf3856ad364e35 ~ ia64 ~ ~ 6.0.2.0.mum不适用1,4262008 年十二月 31 日15: 00不适用
Package_for_kb961451_server_0 ~ 31bf3856ad364e35 ~ ia64 ~ ~ 6.0.2.0.mum不适用1,4292008 年十二月 31 日15: 00不适用
Package_for_kb961451_server ~ 31bf3856ad364e35 ~ ia64 ~ ~ 6.0.2.0.mum不适用1,4342008 年十二月 31 日15: 00不适用
X86_microsoft-窗口-m...nts-mdac 的 rds-ce-dll_31bf3856ad364e35_6.0.6001.22342_none_6251560e5afb6c40.manifest不适用15,0012008 年十二月 31 日04: 57不适用
Msadce.dll6.0.6001.223421,175,5522008 年十二月 31 日04: 41IA 64
Msadce.dll6.0.6001.22342454,6562008 年十二月 31 日04: 23x86

状态

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

更多信息

注意此修复程序不会更改通过 Microsoft OLE DB 提供程序的 ODBC (MSDASQL) ADO 的行为。.有关命名 SQL Server 更新架构的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
822499Microsoft SQL Server 软件更新程序包的新命名架构
有关软件更新术语的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
824684用于描述 Microsoft 软件更新的标准术语的说明

属性

文章编号: 961451 - 最后修改: 2009年8月25日 - 修订: 2.0
这篇文章中的信息适用于:
  • Microsoft Windows XP Service Pack 2
  • Microsoft Windows XP Service Pack 3
  • Microsoft Windows Server 2003 Service Pack 1
  • Microsoft Windows Server 2003 Service Pack 2
  • Windows Vista Service Pack 1
  • Windows Server 2008 Datacenter
  • Windows Server 2008 Enterprise
  • Windows Server 2008 Standard
关键字:?
kbmt kbautohotfix kbsurveynew kbfix kbqfe kbexpertiseadvanced kbhotfixserver KB961451 KbMtzh
机器翻译
注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。
点击这里察看该文章的英文版: 961451
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