• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

sqlserver OpenRowSet 对应的三种数据库驱动

mysql 搞代码 4年前 (2022-01-09) 22次浏览 已收录 0个评论

在使用sqlserver数据库的OpenRowSet函数时,会遇到三种驱动方式: 1. MSDASQL驱动 SELECT TOP 10 * FROM OPENROWSET(‘MSDASQL’, ‘DRIVER={SQL Server};SERVER=xxx;UID=xx;PWD=xxx;’, ‘select * from AdventureWorks.HumanResources.Employee’) 2. SQLNCLI驱

在使用sqlserver数据库的OpenRowSet函数时,会遇到三种驱动方式:

1. MSDASQL驱动
SELECT TOP 10 *
FROM OPENROWSET(‘MSDASQL’, ‘DRIVER={SQL Server};SERVER=xxx;UID=xx;PWD=xxx;’, ‘select * from AdventureWorks.HumanResources.Employee’)

2. SQLNCLI驱动
SELECT TOP 10 *
FROM OPENROWSET(‘SQLNCLI’, ‘SERVER=xxx;UID=xx;PWD=xxxxx;’, ‘select * from AdventureWorks.HumanResources.Employee’)

3. SQLOLEDB驱动
SELECT TOP 10 *
FROM OpenRowSet(‘SQLOLEDB’, ‘xxx’; ‘xx’; ‘xxx’, AdventureWorks.HumanResources.Employee)

先看一下定义

MSDASQL:Microsoft OLE DB Provider for ODBC Drivers

允许在 OLEDB 和 ADO(它在内部使用 OLEDB)上构建的应用程序通过 ODBC 驱动程序访问数据源的技术。
MSDASQL 是用于连接到 ODBC(而不是数据库)的 OLEDB 访问接口。

SQLOLEDB :Microsoft OLE DB Provider for SQL Server,可以看出来SQLOLEDB是连接到数据库sqlserver,而不是ODBC驱动

SQLNCLI10(SQLNCLI):SQL Server Native Client 10.0

SQL Server Native Client的定义:

SQL Server Native Client 是在 SQL Server 2005 中引入的用于 OLE DB 和 ODBC 的独立数据访问应用程序编程接口 (API)。SQL Server Native Client 将 SQL OLE DB 访问接口和 SQL ODBC 驱动程序组合成一个本机动态链接库 (DLL)。为了利用在 SQL Server 2005以及以上的版本的新功能,比如多个活动结果集 (MARS)、查询通知、用户定义类型 (UDT) 或新的 xml 数据类型,那些使用 ActiveX Data Objects (ADO) 的现有应用程序应当使用 SQL Server Native Client OLE DB 访问接口作为其数据访问接口。

如果不需要使用在 SQL Server 2005 及其以后的版本中引入的任何新功能,则不需要使用 SQL Server Native Client OLE DB 访问接口;您可以继续使用当前数据访问接口(通常是 SQLOLEDB)。如果要增强现有应用程序的功能,并且需要使用在 SQL Server 2005 及其以后的版本中引入的新功能,则应当使用 SQL Server Native Client OLE DB 访问接口。

附上 OPENROWSET 语法格式

OPENROWSET <strong>(</strong> { <strong>'</strong><em>provider_name</em><strong>'</strong> <strong>,</strong> { <strong>'</strong><em>datasource</em><strong>'</strong> <strong>;</strong> <strong>'</strong><em>user_id</em><strong>'</strong> <strong>;</strong> <strong>'</strong><em>password</em><strong>'</strong>    | <strong>'</strong><em>provider_string</em><strong>' </strong>}       <strong>,</strong> {   [ <em>catalog</em><strong>.</strong> ] [ <em>schema</em><strong>. </strong>] <em>object</em>        | <strong>'</strong><em>query</em><strong>'</strong>      }    | BULK <strong>'</strong><em>data_file</em><strong>'</strong> <strong>,</strong>        { FORMATFILE <strong>=</strong> <strong>'</strong><em>format_file_path</em><strong>'</strong> [  ]       | SINGLE_BLOB | SINGLE_CLOB | SINGLE_NCLOB }} <strong>)</strong>  ::=   [ <strong>,</strong> CODEPAGE <strong>=</strong> { <strong>'</strong>ACP<strong>'</strong> | <strong>'</strong>OEM<strong>'</strong> | <strong>'</strong>RAW<strong>'</strong> | <strong>'</strong><em>code_page</em><strong>'</strong> } ]    [ <strong>,</strong> ERRORFILE <strong>=</strong> <strong>'</strong><em>file_name</em><strong>'</strong> ]   [ <strong>,</strong> FIRSTROW <strong>=</strong> f<em>irst_row </em>]    [ <strong>,</strong> LASTROW <strong>=</strong> la<em>st_row </em>]    [ <strong>,</strong> MAXERRORS <strong>=</strong> m<em>aximum_errors </em>]    [ <strong>,</strong> ROWS_PER_BATCH <strong>=</strong> <em>rows_per_batch </em>] <br /><br />[ <strong>,</strong> ORDER ( { column [ ASC | DESC ] } [ <strong>,</strong>...<em>n</em> ] ) [ UNIQUE ] 

参照:http://www.cnblogs.c

本文来源gao!%daima.com搞$代*!码9网(

om/w-y-f/archive/2012/05/07/2488474.html


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:sqlserver OpenRowSet 对应的三种数据库驱动

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址