代码改变世界

SQL Server 2005分布式查询之传递查询

2011-10-26 23:23  Echo.  阅读(165)  评论(0)    收藏  举报

 

SQL Server 2005中除链接服务器外,只有通过OPENQUERY,OPENROWSET,OPENDATASOURCE三种方式访问外部数据源.先上三种函数的语法:
OPENQUERY ( linked_server ,'query' )
OPENROWSET ( { 'provider_name' , { 'datasource' ; 'user_id' ; 'password'    | 'provider_string' }       
, { [ catalog. ] [ schema. ] object     | 'query' }  
  | BULK 'data_file' ,        { FORMATFILE = 'format_file_path' [ <bulk_options> ]     
   | SINGLE_BLOB | SINGLE_CLOB | SINGLE_NCLOB } } ) 
OPENDATASOURCE ( provider_name, init_string )

红色标记的'query'则是.SQL Server 2005访问异类数据源查询语句,并且SQL Server 2005不会预先分析该语句,所以查询必须使用OLE DB访问接口可以接受的语法,T-SQL可以像使用常规表一

样引用传递查询的结果。
以下两种方法可以从 OLE DB 访问接口中生成行集:
1.引用访问接口可以显示为表格格式行集的数据源中的对象。所有访问接口都支持这一功能。
2.向访问接口发出一条命令,该命令应可以由访问接口处理且处理结果可以显示为行集。此功能要求访问接口支持 OLE DB Command 对象及其所有必需接口。

当访问接口支持 Command 对象时,以下 Transact-SQL 函数可以用来发送命令(称为传递查询):
1.OPENQUERY 使用链接服务器名称向 OLE DB 数据源发送命令字符串。
2.OPENROWSET 和 OPENDATASOURCE支持向 OLE DB 数据源发送命令字符串。可以使用即席名称引用所得到的行集。
通过上面三种语法可以看出OPENQUERY,OPENROWSET支持传递查询,而OPENDATASOURCE只能当作四部分名称中的第一部分名称在T-SQL调用。

OPENROWSET 和 OPENQUERY 支持传递查询,其中只有在查询具有以下特征之一时,查询字符串才包含存储过程调用:

1.执行单个静态的 SELECT 语句。
2.不使用任何动态的 EXECUTE 语句。
3.不执行任何数据修改操作。

OLE DB 规范并未定义一种所有 OLE DB 访问接口必须使用的命令语言。OLE DB 访问接口可以支持与所公开数据相关的任意命令语言。公开关系数据库数据的 OLE DB 访问接口通常支持 SQL 

语言。其他类型的访问接口(例如表现电子邮件文件或网络目录中的数据的访问接口)通常支持另一种语言。