跨数据库实现数据交流
程序员文章站
2022-07-12 07:50:27
通常情况下,我们的crud操作都在单一数据库中进行。但是,也可能会遇到需要进行跨数据交流的情况。对此,我以跨数据库进行表的访问为例,稍微总结了下。
一、同sql serv...
通常情况下,我们的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也能实现跨服务器访问数据,但它是基于已经建立链接服务器的基础上来操作的,应属第一种方法,在此不再赘述。
以上就是跨数据库实现数据交流的方法,希望大家可以亲自动手操作一下。
下一篇: python开发封装(请求头封装)
推荐阅读
-
php批量更改数据库表前缀实现方法
-
PHP使用PDO、mysqli扩展实现与数据库交互操作详解
-
MySQL数据库实现MMM高可用群集架构
-
php实现mysql数据库连接操作及用户管理
-
在代码生成工具Database2Sharp中使用ODP.NET(Oracle.ManagedDataAccess.dll)访问Oracle数据库,实现免安装Oracle客户端,兼容32位64位Oracle驱动
-
基于Enterprise Library的Winform开发框架实现支持国产达梦数据库的扩展操作
-
微信小程序实现用table显示数据库反馈的多条数据功能示例
-
微信小程序实现获取用户信息并存入数据库操作示例
-
android实现raw文件夹导入数据库代码
-
Android实现与Apache Tomcat服务器数据交互(MySql数据库)