sqlserver调oracle怎么接收返回表
接收Oracle返回的表在SQL Server中,可以通过使用Linked Server来实现。Linked Server是SQL Server中的一个功能,可以在SQL Server中连接到其他数据库系统,包括Oracle。以下是具体的步骤:
1 在SQL Server中创建一个Linked Server,指向Oracle数据库。可以使用SQL Server Management Studio中的“对象资源管理器”来创建Linked Server,或者使用T-SQL命令来创建。
2 在创建Linked Server时,需要指定连接到Oracle数据库的相关信息,包括服务器名称、登录信息和数据库名称等。
3 一旦创建了Linked Server,你可以使用四部分名称(四部分名称由服务器名称、目录名称、模式名称和表名称组成)来引用Oracle数据库中的表,就像引用本地SQL Server中的表一样。
4 在SQL Server中执行查询时,可以使用OPENQUERY函数或者直接使用四部分名称引用Oracle表。OPENQUERY函数可以在查询中使用,以便在Oracle数据库上执行特定的查询,并将结果返回给SQL Server。
原因解释:
SQL Server和Oracle是两个不同的数据库系统,它们的数据结构和查询语言有所不同。通过创建Linked Server,可以在SQL Server中建立与Oracle数据库的连接,并允许从Oracle数据库中检索数据。这样可以在SQL Server环境中方便地处理和分析Oracle数据库中的数据,而无需进行数据导出和导入操作。
拓展内容:
除了使用Linked Server,还可以使用其他方法来实现SQL Server调用Oracle返回表的需求。例如,可以使用ETL工具(如SSIS)将Oracle数据导入到SQL Server中进行处理,或者使用数据复制技术将Oracle数据库的数据实时复制到SQL Server中。这些方法的选择取决于具体的业务需求和数据处理的复杂程度。
12337举报平台进度查询页面打不开链接服务器超时。查询页面打不来是连接服务器超时,是网络的问题,重新连一下网络。,过一段时间再上,临时他的服务器不稳定。12337指全国扫黑办智能化举报平台。全国扫黑办智能化举报平台,是全国扫黑除恶专项斗争领导小组办公室向社会公开发布升级后的智能化举报平台。
1首先连接本机服务器(在VS编辑器中 数据库连接时,选择本机服务器名),用SQL语句取出表A和表B的数据,写入到一个新建的数据库中 2连接局域网中另一个你需要连接的数据库,用SQL语句取出表C和表D的数据,写到上面新建的数据库中。 3在同一个数据库中做连接查询就是了
1 如果不知道怎么连接服务器
a 要安装sqlserver客户端
b 数据库连接参数中,至少有四项:服务器\实例名,数据库,用户,密码
c 要保证数据库服务正常启动
d 要保证客户端到服务器网络通畅
2 如果是linkedserver ,那么看下面,并到网络上搜索一下:
sp_addlinkedserver
创建一个链接的服务器,使其允许对分布式的、针对 OLE DB 数据源的异类查询进行访问。在使用 sp_addlinkedserver 创建链接的服务器之后,此服务器就可以执行分布式查询。如果链接服务器定义为 Microsoft® SQL Server™,则可执行远程存储过程。
语法
sp_addlinkedserver [ @server = ] 'server'
[ , [ @srvproduct = ] 'product_name' ]
[ , [ @provider = ] 'provider_name' ]
[ , [ @datasrc = ] 'data_source' ]
[ , [ @location = ] 'location' ]
[ , [ @provstr = ] 'provider_string' ]
[ , [ @catalog = ] 'catalog' ]
适用环境
操作系统:windows 2003
数据库:sql server 2000/sql server 2003
使用链接服务器进行远程数据库访问的情况
一、问题现象
在执行分布式事务时,在sql server 2005下收到如下错误:
消息 7391,级别 16,状态 2,过程 xxxxx,第 16 行
无法执行该操作,因为链接服务器 "xxxxx" 的 OLE DB 访问接口 "SQLNCLI" 无法启动分布式事务。
在sql server 2000下收到如下错误:
该操作未能执行,因为 OLE DB 提供程序 'SQLOLEDB' 无法启动分布式事务。
[OLE/DB provider returned message: 新事务不能登记到指定的事务处理器中。 ]
OLE DB 错误跟踪[OLE/DB Provider 'SQLOLEDB' ITransactionJoin::JoinTransaction returned 0x8004d00a]。
二、解决方案
1双方启动MSDTC服务
MSDTC服务提供分布式事务服务,如果要在数据库中使用分布式事务,必须在参与的双方服务器启动MSDTC(Distributed Transaction Coordinator)服务。
2打开双方135端口
MSDTC服务依赖于RPC(Remote Procedure Call (RPC))服务,RPC使用135端口,保证RPC服务启动,如果服务器有防火墙,保证135端口不被防火墙挡住。
使用“telnet IP 135 ”命令测试对方端口是否对外开放。也可用端口扫描软件(比如Advanced Port Scanner)扫描端口以判断端口是否开放。
3保证链接服务器中语句没有访问发起事务服务器的操作
在发起事务的服务器执行链接服务器上的查询、视图或存储过程中含有访问发起事务服务器的操作,这样的操作叫做环回(loopback),是不被支持的,所以要保证在链接服务器中不存在此类操作。
4在事务开始前加入set xact_abort ON语句
对于大多数 OLE DB 提供程序(包括 SQL Server),必须将隐式或显示事务中的数据修改语句中的 XACT_ABORT 设置为 ON。唯一不需要该选项的情况是在提供程序支持嵌套事务时。
5MSDTC设置
打开“管理工具——组件服务”,以此打开“组件服务——计算机”,在“我的电脑”上点击右键。在MSDTC选项卡中,点击“安全配置”按钮。
在安全配置窗口中做如下设置:
l选中“网络DTC访问”
l在客户端管理中选中“允许远程客户端”“允许远程管理”
l在事务管理通讯中选“允许入站”“允许出站”“不要求进行验证”
l保证DTC登陆账户为:NTAuthority\NetworkService
6链接服务器和名称解析问题
建立链接sql server服务器,通常有两种情况:
l第一种情况,产品选”sql server”
EXEC sp_addlinkedserver
@server='linkServerName',
@srvproduct = N'SQL Server'
这种情况,@server (linkServerName)就是要链接的sqlserver服务器名或者ip地址。
l第二种情况,访问接口选“Microsoft OLE DB Provider Sql Server”或“Sql Native Client”
EXEC sp_addlinkedserver
@server=' linkServerName ',
@srvproduct='',
@provider='SQLNCLI',
@datasrc='sqlServerName'
这种情况,@datasrc(sqlServerName)就是要链接的实际sqlserver服务器名或者ip地址。
Sql server数据库引擎是通过上面设置的服务器名或者ip地址访问链接服务器,DTC服务也是通过服务器名或者ip地址访问链接服务器,所以要保证数据库引擎和DTC都能通过服务器名或者ip地址访问到链接服务器。
数据库引擎和DTC解析服务器的方式不太一样,下面分别叙述
61数据库引擎
第一种情况的@server或者第二种情况的@datasrc设置为ip地址时,数据库引擎会根据ip地址访问链接服务器,这时不需要做名称解析。
第一种情况的@server或者第二种情况的@datasrc设置为sql server服务器名时,需要做名称解析,就是把服务器名解析为ip地址。
有两个办法解析服务器名:
一是在sql server客户端配置中设置一个别名,将上面的服务器名对应到链接服务器的ip地址。
二是在“C:\WINDOWS\system32\drivers\etc\hosts”文件中增加一条记录:
xxxxxxxxxxxx服务器名
作用同样是把服务器名对应到链接服务器的ip地址。
62DTC
不管哪一种情况,只要@server设置的是服务器名而不是ip地址,就需要进行名称解析,办法同上面第二种办法,在hosts文件中增加解析记录,上面的第一种办法对DTC不起作用。
如果@server设置的是ip地址,同样不需要做域名解析工作。
1、进入控制面板的网络和共享中心,在最上方的“查看基本网络信息并设置连接”的右侧选择“查看完整映射”就可以了
2、开始——运行—— 输入 :cmd 键入 ipconfig /all
3、右击网络链接,打开网络和共享中心,打开网络链接,看详细属性
0条评论