exec sp_addlinkedserver 'srv_lnk','','SQLOLEDB','远程服务器名或ip地址'
exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'用户名','密码'
go-- 把远程数据库的内容插入到本地的表中
insert into table1 select * from srv_lnk.数据库名.dbo.table1

解决方案 »

  1.   

    建立远程数据库连接 srv_lnk
    insert into table select * from srv_lnk.数据库名.dbo.table
      

  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.   

    两个数据库中的两张表(结构相同)合并成一张。
    db1.table1
    +---+--------+
    | a | b      |
    +---+--------+
    | 1 | 1      |
    | 2 | 2      |
    | 3 | 3      |
    +---+--------+db2.table1
    +---+--------+
    | a | b      |
    +---+--------+
    | 1 | 4      |
    | 2 | 5      |
    +---+--------+合并成:+---+--------+
    | a | b      |
    +---+--------+
    | 1 | 1      |
    | 2 | 2      |
    | 3 | 3      |
    | 4 | 4      |
    | 5 | 5      |
    +---+--------+
    有什么好方法?