跨数据库数据交流

发表于:2015-8-12 09:36

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:Figgy    来源:51Testing软件测试网采编

  通常情况下,我们的CRUD操作都在单一数据库中进行。但是,也可能会遇到需要进行跨数据交流的情况。对此,我以跨数据库进行表的访问为例,稍微总结了下。
  一、同SQL SERVER
  这个最简单。直接在表名前加上"[数据库名]."就可以了。
  例:
  SELECT * FROM [DestinationDBName].dbo.DestinationTableName
  二、跨SQL SERVER
  主要介绍两种方法:
  (一)通过链接服务器
  1.先执行系统存储过程 sp_addlinkedserver :
  EXEC sp_addlinkedserver
  @server='DestinationDBAlias',--目标数据库的别名,在连接并登录后,就可以用它来访问数据
  @srvproduct='',
  @provider='SQLOLEDB',
  @datasrc='DestinationServerIP\ServerName'--通常用"IP\端口名"组成,如果服务器上只装了一个MSSQL SERVER,或者装了多个MS SQLSERVER,但要访问的是默认端口,就不用加端口名
  2.再执行系统存储过程 sp_addlinkedsrvlogin:
  EXEC sp_addlinkedsrvlogin
  @rmtsrvname='DestinationDBAlias',--注意这里的名字应与第一步sp_addlinkedserver中@server值一致
  @useself='false',
  @locallogin=NULL,
  @rmtuser='UserName',
  @rmtpassword='Password'
  3.现在,我们可以通过目标数据库别名访问数据:
  例:
  SELECT * FROM [DestinationDBAlias].dbo.DestinationTableName
  4.使用结束,不要忘了断开与目标数据库的连接:
  EXEC sp_dropserver
  @server='DestinationDBAlias',--注意这里的名字应与第一步sp_addlinkedserver中@server值一致
  @droplogins='droplogins'
  (二)使用OPENDATASOURCE/OPENROWSET连接远程服务器
  SELECT * FROM OPENDATASOURCE
  ('SQLOLEDB', --provider_name
  'Data Source=DestinationServerIP;User ID=UserName;Password=Password' --provider_string(datasource;user_id;password)
  ).[DestinationDBAlias].dbo.DestinationTableName
  SELECT * FROM OPENROWSET
  ('SQLOLEDB',--provider_name
  'DestinationServerIP';'UserName';'Password',--provider_string(datasource;user_id;password)
  'SELECT * FROM [DestinationDBAlias].dbo.DestinationTableName')--query_string
  函数OPENQUERY也能实现跨服务器访问数据,但它是基于已经建立链接服务器的基础上来操作的,应属第一种方法,在此不再赘述。
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号