exec  sp_addlinkedserver    
       @server='DPVSERVER1', @srvproduct='',
       @provider='SQLOLEDB', @datasrc='ServerB'
go
exec  sp_addlinkedsrvlogin 
 @rmtsrvname =  'DPVSERVER1'
     , @useself =  'false' 
     , @rmtuser =  'sa' 
     , @rmtpassword = 'password' 
go
insert into aaa(a,b)
select UserId,CityId from DPVSERVER1.wjWeb.dbo.CommpanyMember

解决方案 »

  1.   

    楼上:DPVSERVER1 这是不是应该写对方的计算机名啊?
    ServerB 这是什么意思啊??我在@datasrc='ServerB'这里应该用什么代替ServerB啊??
    不管我用wjWeb代替ServerB,还时保持ServerB不变(:DPVSERVER1  处我写的对方计算机用户名)为什么老是提示:命名管道提供程序: 无法打开与 SQL Server 的连接 [53]. 大侠我应怎么改呢??
      

  2.   

    exec   sp_addlinkedserver     '链接服务器名','','SQLOLEDB','远程服务器名或ip地址'   
        
      --连接远程服务器   
        
      exec   sp_addlinkedsrvlogin   '链接服务器名','false',null,'用户名','密码'   
                    
      --指本地登陆的用户如何映射远程服务器的用户,null表示所有的本地登陆都映射到远程的用户'用户名'.   
      

  3.   

    --创建链接服务器
    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.表名)