MSSQL跨库查询表数据 (分布式查询)

2021-08-16 15:08:14 浏览数 (1)

因为我的业务数据库和文档数据库非常庞大,所以我分成了两个服务器,但有时需要进行跨库查询,我们就可以利用链接服务器的方法来搞定它。

代码语言:javascript复制
--使用联结服务器
--填加联结服务器:
EXEC sp_addlinkedserver '别名','','MSDASQL',NULL,NULL,'DRIVER={SQL Server};SERVER=远程名;UID=用户;PWD=密码;'
--创建或更新本地 Microsoft? SQL Server? 实例上的登录与链接服务器上远程登录之间的映射。
exec sp_addlinkedsrvlogin  @rmtsrvname='别名',@useself='false',@locallogin='sa',@rmtuser='sa',@rmtpassword='密码'
GO
然后你就可以如下:
select * from 别名.库名.dbo.表名
insert 库名.dbo.表名 select * from 别名.库名.dbo.表名
select * into 库名.dbo.新表名 from 别名.库名.dbo.表名
go

附:详解

sp_addlinkedserver

创建一个链接的服务器,使其允许对分布式的、针对 OLE DB 数据源的异类查询进行访问。在使用 sp_addlinkedserver 创建链接的服务器之后,此服务器就可以执行分布式查询。如果链接服务器定义为 Microsoft® SQL Server™,则可执行远程存储过程。

语法

sp_addlinkedserver [ @server = ] ' server ' [ , [ @srvproduct = ] ' product_name ' ] [ , [ @provider = ] ' provider_name ' ] [ , [ @datasrc = ] ' data_source ' ] [ , [ @location = ] ' location ' ] [ , [ @provstr = ] ' provider_string ' ] [ , [ @catalog = ] ' catalog ' ]

参数

[ @server = ] ' server '

要创建的链接服务器的本地名称,server 的数据类型为 sysname ,没有默认设置。

如果有多个 SQL Server 实例,server 可以为 servername/instancename 。此链接的服务器可能会被引用为下面示例的数据源:

  1. 如果未指定 data_source ,则服务器为该实例的实际名称。

[ @srvproduct = ] ' product_name '

要添加为链接服务器的 OLE DB 数据源的产品名称。product_name 的数据类型为 nvarchar(128) ,默认设置为 NULL。如果是 SQL Server ,则不需要指定 provider_namedata_sourcelocationprovider_string 以及目录。

[ @provider = ] ' provider_name '

与此数据源相对应的 OLE DB 提供程序的唯一程序标识符 (PROGID)。provider_name 对于安装在当前计算机上指定的 OLE DB 提供程序必须是唯一的。provider_name 的数据类型为nvarchar(128) ,默认设置为 NULL。OLE DB 提供程序应该用给定的 PROGID 在注册表中注册。

[ @datasrc = ] ' data_source '

由 OLE DB 提供程序解释的数据源名称。data_source 的数据类型为 nvarchar(4000) ,默认设置为 NULL。data_source 被当作 DBPROP_INIT_DATASOURCE 属性传递以便初始化 OLE DB 提供程序。

当链接的服务器针对于 SQL Server OLE DB 提供程序创建时,可以按照 servername /instancename 的形式指定 data_source, 它可以用来连接到运行于特定计算机上的 SQL Server 的特定实例上。servername 是运行 SQL Server 的计算机名称,instancename 是用户将被连接到的特定 SQL Server 实例的名称。

[ @location = ] ' location '

OLE DB 提供程序所解释的数据库的位置。location 的数据类型为 nvarchar(4000) ,默认设置为 NULL。location 作为 DBPROP_INIT_LOCATION 属性传递以便初始化 OLE DB 提供程序。

[ @provstr = ] ' provider_string '

OLE DB 提供程序特定的连接字符串,它可标识唯一的数据源。provider_string 的数据类型为 nvarchar(4000) ,默认设置为 NULL。Provstr 作为 DBPROP_INIT_PROVIDERSTRING 属性传递以便初始化 OLE DB 提供程序。

当针对 Server OLE DB 提供程序提供了链接服务器后,可将 SERVER 关键字用作 SERVER=servername /instancename 来指定实例,以指定特定的 SQL Server 实例。servername 是 SQL Server 在其上运行的计算机名称,instancename 是用户连接到的特定的 SQL Server 实例名称。

[ @catalog = ] ' catalog '

建立 OLE DB 提供程序的连接时所使用的目录。catalog 的数据类型为sysname ,默认设置为 NULL。catalog 作为 DBPROP_INIT_CATALOG 属性传递以便初始化 OLE DB 提供程序。

返回代码值

0(成功)或 1(失败)

结果集

如果没有指定参数,则 sp_addlinkedserver 返回此消息:

Procedure 'sp_addlinkedserver' expects parameter '@server', which was not supplied. 使用适当 OLE DB 提供程序和参数的 sp_addlinkedserver 返回此消息:

Server added.

MSSQL2000验证通过。

0 人点赞