公司前后开发了两个产品,现在客户要求两个数据库(SqlServer2000)的部分表需要关联起来。可是,麻烦的是现在两个数据库部署在不同的两台服务器上,要求客户变成一个也不现实。有没有办法实现从两个不同数据库中的表进行多表查询呢。也设想过临时表,但是每次要做表数据同步也很麻烦。各位有好的想法请多多建议。

解决方案 »

  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.表名)
    select * from openrowset('SQLOLEDB'
    ,'sql服务器名';'用户名';'密码'
    ,数据库名.dbo.表名)
    openrowset可以用下面两个
    OPENDATASOURCE或是openquery
      

  2.   

    这样的方法在tomcat容器下java web工程可以实现吗。
      

  3.   

    k建立信任接连,然后通知所建立的信任接连进行访问及操作select * from [serverName].[databaseName].dbo.tableName
      

  4.   

    关于此方面我的blog里有一些函数可以调用如OpenRowset等等