把数据存在本机sql 数据库中,要求过一段时间将本机的数据纪录存入服务器中,
本机的数据库中的表和服务器中的表完全一致,如何处理?

解决方案 »

  1.   

    insert into 服务器名.数据库.dba.服务器中的表 select * from 本机的数据库中的表 where ...
      

  2.   

    insert into tablename1 select * from tablename2
      

  3.   

    dawugui(潇洒老乌龟) ( ) 
    怎样把新的纪录存入,已经存完的不载存储?
      

  4.   

    这是所有的方法
    --创建链接服务器
    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
      

  5.   

    在服务器上执行
    insert 服务器上的表
    select * from openrowset('SQLOLEDB'
    ,'sql本地;'用户名';'密码'
    ,数据库名.dbo.表名)as a
    或用生成服务器上的表
    select * into 新表 from openrowset('SQLOLEDB'
    ,'sql本地;'用户名';'密码'
    ,数据库名.dbo.表名)as 
    再执行
    insert 表名
    select * from 新表