Heim > Datenbank > MySQL-Tutorial > SQL SERVER:不同服务器数据库之间的数据操作

SQL SERVER:不同服务器数据库之间的数据操作

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Freigeben: 2016-06-07 16:20:49
Original
1263 Leute haben es durchsucht

不同服务器数据库之间的数据操作 --创建链接服务器 exec sp_addlinkedserver 'ITSV ', ' ', 'SQLOLEDB ', '远程服务器名或ip地址 ' exec sp_addlinkedsrvlogin 'ITSV ', 'false ',null, '用户名 ', '密码 ' --查询示例 select * from ITSV.数据库名。dbo.表

   不同服务器数据库之间的数据操作

  --创建链接服务器

  exec sp_addlinkedserver 'ITSV ', ' ', 'SQLOLEDB ', '远程服务器名或ip地址 '

  exec sp_addlinkedsrvlogin 'ITSV ', 'false ',null, '用户名 ', '密码 '

  --查询示例

  select * from ITSV.数据库名。dbo.表名

  --导入示例

  select * into 表 from ITSV.数据库名。dbo.表名

  --以后不再使用时删除链接服务器

  exec sp_dropserver 'ITSV ', 'droplogins '

  --连接远程/局域网数据(openrowset/openquery/opendatasource)

  --1、openrowset

  --查询示例

  select * from openrowset( 'SQLOLEDB ', 'sql服务器名 '; '用户名 '; '密码 ',数据库名。dbo.表名)

  --生成本地表

  select * into 表 from openrowset( 'SQLOLEDB ', 'sql服务器名 '; '用户名 '; '密码 ',数据库名。dbo.表名)

  --把本地表导入远程表

  insert openrowset( 'SQLOLEDB ', 'sql服务器名 '; '用户名 '; '密码 ',数据库名。dbo.表名)

  select *from 本地表

  --更新本地表

  update b

  set b.列A=a.列A

  from openrowset( 'SQLOLEDB ', 'sql服务器名 '; '用户名 '; '密码 ',数据库名。dbo.表名)as a inner join 本地表 b

  on a.column1=b.column1

  --openquery用法需要创建一个连接

  --首先创建一个连接创建链接服务器

  exec sp_addlinkedserver 'ITSV ', ' ', 'SQLOLEDB ', '远程服务器名或ip地址 '

  --查询

  select *

  FROM openquery(ITSV, 'SELECT * FROM 数据库。dbo.表名 ')

  --把本地表导入远程表

  insert openquery(ITSV, 'SELECT * FROM 数据库。dbo.表名 ')

  select * from 本地表

  --更新本地表

  update b

  set b.列B=a.列B

  FROM openquery(ITSV, 'SELECT * FROM 数据库。dbo.表名 ') as a

  inner join 本地表 b on a.列A=b.列A

  --3、opendatasource/openrowset

  SELECT *

  FROM opendatasource( 'SQLOLEDB ', 'Data Source=ip/ServerName;User ID=登陆名;Password=密码 ' )。test.dbo.roy_ta

  --把本地表导入远程表

  insert opendatasource( 'SQLOLEDB ', 'Data Source=ip/ServerName;User ID=登陆名;Password=密码 ')。数据库。dbo.表名

  select * from 本地表

  1、远程复制

  将本地数据表复制到远程表中,若使用

  SELECT * INTO opendatasource( 'SQLOLEDB ', 'Data Source=ip/ServerName;User ID=登陆名;Password=密码 ')。数据库。dbo.表名

  FROM [本地表]

  将不能出错,系统不允许使用这种方式。

  因此,只能采取先在远程数据库中,建立一张与本地表相同的表,然后使用

  insert opendatasource( 'SQLOLEDB ', 'Data Source=ip/ServerName;User ID=登陆名;Password=密码 ')。数据库。dbo.表名

  select * from 本地表

  进行处理。

  注意:主键和自增量的问题。要先关闭自增量的开关。

  2、UPDATE远程服务器表

  UPDATE a SET

  a.[列名]=b.[列名]

  FROM opendatasource( 'SQLOLEDB ', 'Data Source=ip/ServerName;User ID=登陆名;Password=密码 ')。数据库。dbo.表名 AS a

  INNER JOIN [本地表]

  ON a.[键名]=b.[键名]

  注意的是:UPDATE后面使用的表名,是FROM的一个别名,这很重要!!!

  如果UPDATE后面的表名(蓝a处)使用了远程链接的表名(opendatasource方式),则会将所需替换的(远程表)字段内容,用本地表中第一个字段内容进行替换(所有行都替换成一个值)。

Verwandte Etiketten:
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Aktuelle Ausgaben
Server
Aus 1970-01-01 08:00:00
0
0
0
Server konfigurieren
Aus 1970-01-01 08:00:00
0
0
0
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage