大家好!有个数据库的问题想请教一下。我有两台主机(分别称为A、B),都装了MS SQLSERVER。现在想从B机一个数据库的表里取一些数据给A机里的一个表,不知道该怎样写存储过程? 

解决方案 »

  1.   

    大家好!有个数据库的问题想请教一下。我有两台主机(分别称为A、B),都装了MS SQLSERVER。现在想从B机一个数据库的表里取一些数据给A机里的一个表,不知道该怎样写存储过程? insert into servernameA.databaseA.userA.tbA(id) 
    select id from servernameB.databaseB.userB.tbB前提,在A机注册一个到B机器的连接.
      

  2.   


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

  3.   

    楼上的两位都回答了我的问题。谢谢!但我当时只定了20分,实在不好分。不过
     wangtiecheng解释的更全面,分就给他了。对不住潇洒老乌龟了!