将应用程序从 MDAC 更新到 SQL Server Native Client

SQL Server Native Client 和 Microsoft 数据访问组件(MDAC;从 Windows Vista 开始,数据访问组件现在称为 Windows 数据访问组件或 Windows DAC)之间存在很多差异。虽然都可提供 SQL Server 数据库的本机数据访问,但经过专门设计的 SQL Server Native Client 可以公开 SQL Server 2005 的新功能,且同时保持了与早期版本的向后兼容性。

本主题中的信息有助于将您的 MDAC(或 Windows DAC)应用程序更新到 SQL Server 2005 中附带的 SQL Server Native Client 版本。为了帮助您将此应用程序更新到 SQL Server 2008 R2 中提供的 SQL Server Native Client 版本,请参阅将应用程序从 SQL Server 2005 Native Client 更新到 SQL Server 2008 R2 Native Client

此外,MDAC 包含使用 OLE DB、ODBC 和 ActiveX 数据对象 (ADO) 的组件,而 SQL Server Native Client 仅能实现 OLE DB 和 ODBC(尽管 ADO 可以访问 SQL Server Native Client 的功能)。

SQL Server Native Client 和 MDAC 在以下其他方面还存在区别:

  • 与访问 SQL OLE DB 访问接口相比,使用 ADO 访问 SQL Server Native Client 访问接口的用户可能会发现其筛选功能较少。

  • 如果 ADO 应用程序使用 SQL Server Native Client 并尝试更新计算列,则将会报告错误。对于 MDAC,此更新已接受,但被忽略。

  • SQL Server Native Client 是单个自包含的动态链接库 (DLL) 文件。公开的接口已经保持为最低限度,这样既是为了减轻分发工作,也是为了降低安全风险。

  • 仅支持 OLE DB 和 ODBC 接口。

  • SQL Server Native Client OLE DB 访问接口和 ODBC 驱动程序名称与 MDAC 中使用的不同。

  • 使用 SQL Server Native Client 时,将可以使用由 MDAC 组件提供的用户可访问功能。这包括但不限于以下功能:连接池、ADO 支持以及客户端游标支持。使用这些功能中的任意功能时,SQL Server Native Client 仅提供数据库连接。MDAC 可提供诸如跟踪、管理控件和性能计数器等功能。

  • 应用程序可以将 OLE DB 核心服务与 SQL Server Native Client 一起使用,但如果使用 OLE DB 游标引擎,则应用程序应使用数据类型兼容选项以避免由于游标引擎不能识别新的 SQL Server 2005 数据类型而可能引起的任何潜在问题。

  • SQL Server Native Client 支持访问自 SQL Server 7.0 开始的早期版本的 SQL Server 数据库。

  • SQL Server Native Client 不包含 XML 集成。SQL Server Native Client 支持 SELECT … FOR XML 查询,但不支持任何其他 XML 功能。然而,SQL Server Native Client 确实支持 SQL Server 2005 中引入的 xml 数据类型。

  • SQL Server Native Client 支持仅使用连接字符串属性来配置客户端网络库。如果需要更完整的网络库配置,您必须使用 SQL Server 配置管理器。

  • SQL Server Native Client 与 odbcbcp.dll 不兼容。为了使用 SQL Server Native Client,必须重新生成使用 ODBC 和 bcp API 的应用程序以与 sqlncli10.lib 链接。

  • Microsoft OLE DB provider for ODBC (MSDASQL) 不支持 SQL Server Native Client。如果将 MDAC SQLODBC 驱动程序用于 MSDASQL 或将 MDAC SQLODBC 驱动程序用于 ADO,请在 SQL Server Native Client 中使用 OLE DB。

  • MDAC 连接字符串允许将布尔值 (true) 用于 Trusted_Connection 关键字。SQL Server Native Client 连接字符串必须使用 yes 或 no。

  • 警告和错误已发生小的改动。现在,服务器返回的警告和错误在传递给 SQL Server Native Client 时会保留相同的严重性。如果要依赖于捕获特定的警告和错误,则应当确保已经全面测试了应用程序。

  • SQL Server Native Client 的错误检查比 MDAC 更为严格,也就是说,某些不严格遵从 ODBC and OLE DB 规范的应用程序的行为可能有所不同。例如,SQLOLEDB 访问接口不强制执行结果参数的参数名称必须以“@”开头这一规则,而 SQL Server Native Client OLE DB 访问接口却强制执行这一规则。

  • 对于失败的连接,SQL Server Native Client 与 MDAC 的行为有所不同。例如,对于失败的连接 MDAC 将返回缓存的属性值,而 SQL Server Native Client 将向调用应用程序报告错误。

  • SQL Server Native Client 不会生成 Visual Studio Analyzer 事件,而是生成 Windows 跟踪事件。

  • SQL Server Native Client 不能与 perfmon 一起使用。Perfmon 是一种 Windows 工具,它仅可与使用 Windows 附带的 MDAC SQLODBC 驱动程序的 DSN 一起使用。

  • SQL Server Native Client 连接到 SQL Server 2005 时,服务器错误 16947 会作为 SQL_ERROR 返回。定位更新无法更新行或定位删除无法删除行时,会出现此错误。对于 SQL Server 2000 和早期版本,当 MDAC 连接到任何版本的 SQL Server 时,服务器错误 16947 会作为警告 (SQL_SUCCESS_WITH_INFO) 返回。

  • SQL Server Native Client 实现 IDBDataSourceAdmin 接口(是一个以前未实现的可选 OLE DB 接口),不过只实现此可选接口的 CreateDataSource 方法。后续版本的 Microsoft SQL Server 将删除该功能。请避免在新的开发工作中使用该功能,并着手修改当前还在使用该功能的应用程序。

  • 在 TABLE_TYPE 设置为 SYNONYM 的情况下,SQL Server Native Client OLE DB 访问接口返回 TABLES 和 TABLE_INFO 架构行集中的同义词。

  • 数据类型 varchar(max)nvarchar(max)varbinary(max)xmludt 或其他大型对象类型的返回值不能返回到早于 SQL Server 2005 的客户端版本。如果希望将这些类型用作返回值,则必须使用 SQL Server Native Client。

  • MDAC 允许在手动事务和隐式事务启动时执行以下语句,但 SQL Server Native Client 不允许。这些语句必须以自动提交模式执行。

    • 所有全文操作(索引和目录 DDL)

    • 所有数据库操作(创建数据库、更改数据库以及删除数据库)

    • Reconfigure

    • Shutdown

    • Kill

    • Backup

  • MDAC 应用程序连接到 SQL Server 时,SQL Server 2005 中引入的数据类型将显示为与 SQL Server 2000 兼容的数据类型,如下表所示。

    SQL Server 2005 类型

    SQL Server 2000 类型

    varchar(max)

    text

    nvarchar(max)

    ntext

    varbinary(max)

    image

    udt

    varbinary

    xml

    ntext

    此类型映射会影响为列元数据返回的值。例如,text 列的最大大小为 2,147,483,647,但 SQL Server Native Client ODBC 报告 varchar(max) 列的最大大小为 SQL_SS_LENGTH_UNLIMITED,而 SQL Server Native Client OLE DB 报告 varchar(max) 列的最大大小为 2,147,483,647 或 -1,具体取决于平台。

  • 出于向后兼容的原因,SQL Server Native Client 允许连接字符串中存在多义性(例如,可能多次指定某些关键字,以及可能允许基于位置或优先级对发生冲突的关键字进行冲突解决)。SQL Server Native Client 的未来版本可能不允许连接字符串中存在多义性。在修改要使用 SQL Server Native Client 的应用程序时,最好消除对连接字符串多义性的任何依赖。

  • 如果使用 ODBC 或 OLE DB 调用来启动事务,则 SQL Server Native Client 和 MDAC 的行为会有所不同;使用 SQL Server Native Client 时将立即启动事务,但使用 MDAC 时事务将在第一次数据库访问后开始启动。这可能会影响存储过程和批处理的行为,因为 SQL Server 要求不管是在批处理或存储过程执行结束后还是在该批处理或存储过程启动时 @@TRANCOUNT 均应相同。有关详细信息,请参阅在存储过程和触发器中回滚和提交

  • 使用 SQL Server Native Client,ITransactionLocal::BeginTransaction 将导致事务立即启动。如果使用 MDAC,则事务会延迟,直到应用程序已执行要求事务处于隐式事务模式的语句后才启动。有关详细信息,请参阅 SET IMPLICIT_TRANSACTIONS (Transact-SQL)

  • 将 SQL Server Native Client 驱动程序与 System.Data.Odbc 一起使用以访问提供特定于 SQL Server 的新数据类型或功能的 SQL Server 服务器计算机时可能会遇到错误。System.Data.Odbc 提供一般 ODBC 实现并且随后不会公开供应商的特定功能或扩展插件。(SQL Server Native Client 驱动程序已更新为可本机支持最新的 SQL Server 功能。)若要解决该问题,可以恢复到 MDAC 或迁移到 System.Data.SqlClient

SQL Server Native Client 和 MDAC 都支持使用行版本控制的已提交读事务隔离,但只有 SQL Server Native Client 支持快照事务隔离。(就编程而言,使用行版本控制的已提交读事务隔离等同于已提交读事务。)有关详细信息,请参阅选择基于行版本控制的隔离级别