当前位置:  数据库>sqlserver

SQLServer 跨库查询实现方法

    来源: 互联网  发布时间:2014-10-04

    本文导语:  本文给出一条 SQL 语句用于展示在同一名服务器上,不同的数据库间查询,注意当前连接用户要对两个库都有权限SQL Server 中 SQL 语句中对象的完整表达式是: [DatabaseServer].[DatabaseName].[DatabaseSchema].[DatabaseObject] 本文给出一条 SQL ...

本文给出一条 SQL 语句用于展示在同一名服务器上,不同的数据库间查询,注意当前连接用户要对两个库都有权限
SQL Server 中 SQL 语句中对象的完整表达式是:

[DatabaseServer].[DatabaseName].[DatabaseSchema].[DatabaseObject]

本文给出一条 SQL 语句用于展示在同一名服务器上,不同的数据库间查询,注意当前连接用户要对两个库都有权限。
代码如下:

select *
from CfteaDb1.dbo.CfteaTable1 inner join CfteaDb2.dbo.CfteaTable2
on CfteaDb1.dbo.CfteaTable1.Id=CfteaDb2.dbo.CfteaTable2.Id

以上在 SQL Server 2008 R2 的 Management Studio 中测试成功。

下面是一些补充资料

不使用链接的服务器名,而提供特殊的连接信息,并将其作为四部分对象名的一部分。

语法
OPENDATASOURCE ( provider_name, init_string )

参数
provider_name

注册为用于访问数据源的 OLE DB 提供程序的 PROGID 的名称。provider_name 的数据类型为 char,没有默认值。

init_string

连接字符串,这些字符串将要传递给目标提供程序的 IDataInitialize 接口。提供程序字符串语法是以关键字值对为基础的,这些关键字值对由分号隔开,例如:"keyword1=value; keyword2=value."

在 Microsoft® Data Access SDK 中定义了基本语法。有关所支持的特定关键字值对的信息,请参见提供程序中的文档。下表列出 init_string 参数中最常用的关键字。
关键字 OLE DB 属性 有效值和描述 数据源 DBPROP_INIT_DATASOURCE 要连接的数据源的名称。不同的提供程序用不同的方法对此进行解释。对于 SQL Server OLE DB 提供程序来说,这会指明服务器的名称。对于 Jet OLE DB 提供程序来说,这会指明 .mdb 文件或 .xls 文件的完整路径。 位置 DBPROP_INIT_LOCATION 要连接的数据库的位置。 扩展属性 DBPROP_INIT_PROVIDERSTRING 提供程序特定的连接字符串。 连接超时 DBPROP_INIT_TIMEOUT 超时值,在该超时值后,连接尝试将失败。 用户 ID DBPROP_AUTH_USERID 用于该连接的用户 ID。 密码 DBPROP_AUTH_PASSWORD 用于该连接的密码。 目录 DBPROP_INIT_CATALOG 连接到数据源时的初始或默认的目录名称。
注释
OPENDATASOURCE 函数可以在能够使用链接服务器名的相同 Transact-SQL 语法位置中使用。因此,就可以将 OPENDATASOURCE 用作四部分名称的第一部分,该名称指的是 SELECT、INSERT、UPDATE 或 DELETE 语句中的表或视图的名称;或者指的是 EXECUTE 语句中的远程存储过程。当执行远程存储过程时,OPENDATASOURCE 应该指的是另一个 SQL Server。OPENDATASOURCE 不接受参数变量。

与 OPENROWSET 函数类似,OPENDATASOURCE 应该只引用那些不经常访问的 OLE DB 数据源。对于访问次数稍多的任何数据源,请为它们定义链接的服务器。无论 OPENDATASOURCE 还是 OPENROWSET 都不能提供链接的服务器定义的全部功能,例如,安全管理以及查询目录信息的能力。每次调用 OPENDATASOURCE 时,都必须提供所有的连接信息(包括密码)。

示例
下面的示例访问来自某个表的数据,该表在 SQL Server 的另一个实例中。
代码如下:

SELECT *
FROM OPENDATASOURCE(
'SQLOLEDB',
'Data Source=ServerName;User ID=MyUID;Password=MyPass'
).Northwind.dbo.Categories

下面是个查询的示例,它通过用于 Jet 的 OLE DB 提供程序查询 Excel 电子表格。
代码如下:

SELECT *
FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
'Data Source="c:Financeaccount.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions

    
 
 

您可能感兴趣的文章:

  • 简单实现SQLServer转MYSQL的方法
  • JSP网页向SQLSERVER同时提交7万多字,怎么实现!
  • SqlServer 序号列的实现方法
  • sqlserver中触发器+游标操作实现
  • SQLServer用存储过程实现插入更新数据示例
  • SqlServer实现类似Oracle的before触发器示例
  • c#实现sqlserver事务处理示例
  • SQLServer行转列实现思路记录
  • sqlserver 手工实现差异备份的步骤
  • C#操作图片读取和存储SQLserver实现代码
  • Oracle与SQLServer的实现互连
  • sqlserver实现oracle的sequence方法
  • asp.net+ajax+sqlserver自动补全功能实现解析
  • sqlserver数据库使用存储过程和dbmail实现定时发送邮件
  • C#控制台程序实现开启、关闭SQLServer服务的代码分享
  • sqlserver 存储过程动态参数调用实现代码
  • SQLserver删除某数据库中所有表实现思路
  • SQLserver 实现分组统计查询(按月、小时分组)
  • 利用脚本自动安装SQLServer的实现步骤分析
  • SQLServer 2005 实现数据库同步备份 过程-结果-分析
  • 通过SQLSERVER重启SQLSERVER服务和计算机的方法
  • 设置密码保护的SqlServer数据库备份文件与恢复文件的方法
  • 使用cmd命令行窗口操作SqlServer的方法
  • SQLSERVER的版本信息和SP补丁信息查看方法
  • sqlserver 2000中创建用户的图文方法
  • sqlserver只有MDF文件恢复数据库的方法
  • SQLserver查询数据类型为ntext是空或NULL值的方法
  • sqlserver中将varchar类型转换为int型再进行排序的方法
  • sqlserver 查询数据库大小的方法
  • sqlserver中更改数据库所属为dbo的方法
  • SQLServer2005 按照日期自动备份的方法
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 连接sqlserver的url是jdbc:microsoft:sqlserver://192.168.0.100:1433,他连那一个数据库呢?
  • (100分)用Microsoft jdbc Driver for sqlserver2000(type4)访问sqlserver2k的问题,help!
  • 怎样用文JDBC for sqlserver访问SQLSERVER 数据库请大侠给出一个完整的程序代码
  • (100分)jdbc连接sqlserver 200出错.[SQLServer 2000 Driver for JDBC]Error establishing socket.
  • 如何连接sqlserver2000数据库
  • 深入JDBC sqlserver连接写法的详解
  • how to 连接到sqlserver2000?
  • 请问如何直接sqlserver?
  • SQLServer JDBC Driver
  • 在sqlserver2000时中文问题。
  • 如何使用JSP 连接SQLSERVER数据库,请不吝赐教!(在线等,急救!)
  • 求助!SQLServer2000 JDBC Driver 不能加载?
  • Resin+Jsp+Sqlserver2000的问题!在线等候!
  • applet用jdbc链接SQLServer 2000的问题
  • 请问连接SQLServer 的驱动器是什么呢?
  • JSP网页向SQLSERVER同时提交7万多字,怎么实现! iis7站长之家
  • 如何用SQLServer2k-JDBC连接数据库?
  • shell脚本读取rrd文件将数据插入sqlserver数据库中
  • 关于用jdbc连接sqlserver2000的问题(在线)
  • 到什么地方去下载在jbuilder6.0中使用sqlserver2000的驱动程序呀?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3