加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQL Server访问Oracle查询性能问题解决

发布时间:2016-10-17 10:03:00 所属栏目:MsSql教程 来源:站长网
导读:1. 问题 系统有个模块,需要查询Oracle数据库中的数据。目前是通过建立链接服务器实现的。 SQLServer访问Oracle实现 可参考这篇文章http://www.cnblogs.com/gnielee/archive/2010/09/07/access-oracle-from-sqlserver.html 目前的查询语句就是一个简单的带

1. 问题

系统有个模块,需要查询Oracle数据库中的数据。目前是通过建立链接服务器实现的。

SQLServer访问Oracle实现 可参考这篇文章http://www.cnblogs.com/gnielee/archive/2010/09/07/access-oracle-from-sqlserver.html

目前的查询语句就是一个简单的带where条件的查询语句,类似如下:

SELECT*FROM LINKED_NAME..ACCOUNT_NAME.TABLE_NAME WHERE COLUMN1=SID;

存在的问题是查询速度非常慢,前台报超时。所以准备提升下查询的性能

2. 分析

首先,确定远程Oracle的表在筛选字段上是否存在索引。经确认,存在索引。

然后,在SSMS客户端中查看了执行语句的执行计划,如下:

SQL Server访问Oracle查询性能问题解决

查看本栏目更多精彩内容:http://www.bianceng.cn/database/SQLServer/

从执行计划可以看出,过程没有和自己设想的那样,原以为SQLServer会将整个查询提交到Oracle服务器执行。而实际在远程查询时,并没有加入where条件,而是将结果返回到本地后,在本地执行筛选(有一个筛选器)

这样速度肯定会非常慢,因为查询没有使用到索引查找,需要将远程数据全部传输到本地后才执行筛选,相当于全表扫描,还多了网络传输的时间。

3. 解决

其实只要能将带where条件的查询语句一并提交到Oracle服务器执行远程查询,就可以解决性能问题了。

但问题是OpenQuery不支持参数。见微软MSDNhttp://technet.microsoft.com/zh-cn/library/ms188427.aspx

 

但好在我们可以另辟蹊径,通过拼接动态SQL的方式实现传递查询参数。

OpenQuery使用参数可参考这篇文章:http://www.cnblogs.com/Dannier/archive/2011/09/21/openquery.html

通过这种方式优化后,执行计划变为如下:可以看到实际返回的行数很少了

SQL Server访问Oracle查询性能问题解决

查询速度提升明显,由原来的前台超时到现在的毫秒级。

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读