|
SQL Server 如何将直接传递查询作为表使用 |
来源:网站维护 |
作者:www.weihula.com |
人气: |
2016-7-16 |
|
|
|
|
|
|
|
|
内容提示:Microsoft® SQL Server™ 2000 将直接传递查询作为未解释的查询字符串发送到 OLE DB 数据源。查询必须使用 OLE DB 数据源可以接受的语法。Transact-SQL 语句像使用常规表引用一样使用直接传递查询结果。 |
|
|
|
|
|
|
|
|
|
Microsoft® SQL Server™ 2000 将直接传递查询作为未解释的查询字符串发送到 OLE DB 数据源。查询必须使用 OLE DB 数据源可以接受的语法。Transact-SQL 语句像使用常规表引用一样使用直接传递查询结果。
本示例使用直接传递查询从 Microsoft Access 版本的 Northwind 示例数据库中检索结果集。
SELECT *
FROM OpenRowset('Microsoft.Jet.OLEDB.4.0',
'c:\northwind.mdb';'admin'; '',
'SELECT CustomerID, CompanyName
FROM Customers
WHERE Region = ''WA'' ')
有两种方法可以从 OLE DB 提供程序中生成行集:
·引用提供程序可以表现为表格格式行集的数据源中的对象。所有提供程序都支持这一功能。
·向提供程序发出一条命令,该命令应可以由提供程序处理且处理结果可以表现为行集。此功能要求提供程序支持 OLE DB Command 对象和它的所有强制接口。
当提供程序支持 Command 对象时,这两个 Transact-SQL 函数可以用来发送命令(称为直接传递查询):
·OPENQUERY 使用链接服务器名称向 OLE DB 数据源发送命令字符串。
·OPENROWSET 和 OPEBDATASOURCE 支持向 OLE DB 数据源发送命令字符串。可以使用特殊名称引用所得到的行集。
OLE DB 规范并未定义一种可供所有 OLE DB 提供程序使用的命令语言。OLE DB 提供程序可以支持与所表现数据相关的任意命令语言。表现关系数据库数据的 OLE DB 提供程序通常支持 SQL 语言。其它类型的提供程序(例如表现电子邮件文件或网络目录中的数据的提供程序)通常支持另一种语言。 |
【声明】本文章系本站编辑转载,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如涉及作品内容、版权和其它问题,请在30日内与本站联系,我们将在第一时间删除内容! |
|
|
|
|
|
|
|
|