结构相同的数据库(表和存储过程都相同)分别放在A、B、C上台数据库服务器上,如何用表较高的效率的方法汇总三台服务器上的数据库中的同一个表?

解决方案 »

  1.   

    --创建链接服务器
    exec sp_addlinkedserver  'srv_lnk','','SQLOLEDB','远程服务器名或ip地址'
    exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'用户名','密码'
    go--查询示例
    select * from srv_lnk.数据库名.dbo.表名--导入示例
    select * into 表 from srv_lnk.数据库名.dbo.表名--以后不再使用时删除链接服务器
    exec sp_dropserver 'srv_lnk','droplogins'
    go--如果只是临时访问,可以直接用openrowset
    --查询示例
    select * from openrowset('SQLOLEDB'
    ,'sql服务器名';'用户名';'密码'
    ,数据库名.dbo.表名)
    --导入示例
    select * into 表 from openrowset('SQLOLEDB'
    ,'sql服务器名';'用户名';'密码'
    ,数据库名.dbo.表名)
      

  2.   

    参考以上链接服务器的资料,将B、C服务器分别创建为A的链接服务器,然后在A服务器上:select * from A.数据库名.dbo.表名
    union all
    select * from srv_B.数据库名.dbo.表名
    union all
    select * from srv_C.数据库名.dbo.表名