代码改变世界

SQL语句里连接其它服务器上的数据库(通过TCP/IP),并操作和读取

2012-02-06 13:12  xtsjh0001  阅读(999)  评论(0编辑  收藏  举报

不同服务器数据库之间的数据操作
--创建链接服务器 exec sp_addlinkedserver   'ITSV ', '', 'SQLOLEDB ', '远程服务器名或ip地址 'exec sp_addlinkedsrvlogin 'ITSV ', 'false ',null, '用户名 ', '密码 '
--查询示例 select*from ITSV.数据库名.dbo.表名
--导入示例 select*intofrom ITSV.数据库名.dbo.表名
--以后不再使用时删除链接服务器 exec sp_dropserver  'ITSV ', 'droplogins '
--连接远程/局域网数据(openrowset/openquery/opendatasource) --1、openrowset --查询示例 select*fromopenrowset( 'SQLOLEDB ', 'sql服务器名 '; '用户名 '; '密码 ',数据库名.dbo.表名)
--生成本地表 select*intofromopenrowset( 'SQLOLEDB ', 'sql服务器名 '; '用户名 '; '密码 ',数据库名.dbo.表名)
--把本地表导入远程表 insertopenrowset( 'SQLOLEDB ', 'sql服务器名 '; '用户名 '; '密码 ',数据库名.dbo.表名) select*from 本地表
--更新本地表 update b set b.列A=a.列A fromopenrowset( 'SQLOLEDB ', 'sql服务器名 '; '用户名 '; '密码 ',数据库名.dbo.表名)as a innerjoin 本地表 b on a.column1=b.column1
--openquery用法需要创建一个连接 --首先创建一个连接创建链接服务器 exec sp_addlinkedserver   'ITSV ', '', 'SQLOLEDB ', '远程服务器名或ip地址 '--查询 select*FROMopenquery(ITSV,  'SELECT *  FROM 数据库.dbo.表名 ') --把本地表导入远程表 insertopenquery(ITSV,  'SELECT *  FROM 数据库.dbo.表名 ') select*from 本地表 --更新本地表 update b set b.列B=a.列B FROMopenquery(ITSV,  'SELECT * FROM 数据库.dbo.表名 ') asinnerjoin 本地表 b on a.列A=b.列A
--3、opendatasource/openrowset SELECT   *FROM   opendatasource( 'SQLOLEDB ''Data Source=ip/ServerName;User ID=登陆名;Password=密码 ' ).test.dbo.roy_ta --把本地表导入远程表 insertopendatasource( 'SQLOLEDB ''Data Source=ip/ServerName;User ID=登陆名;Password=密码 ').数据库.dbo.表名 select*from