【达梦数据库】dblink连接[SqlServer/Mysql]报错处理

背景

需要使用dblink功能连接SqlServer/Mysql数据库,在测试时有好几种报错,记录供参考。

问题1:无法测试以ODBC数据源方式访问的外部链接!

在达梦管理工具图形化测试公共外部链接时,报错:无法测试以ODBC数据源方式访问的外部链接!
在这里插入图片描述

问题分析&原因

ODBC类型的外部公共链接没有图形化测试功能

解决方法

直接使用dblink查远端表测试

问题2:DBLINK连接丢失

使用dblink查MYSQL远端表测试,报错:DBLINK连接丢失
在这里插入图片描述

问题分析&原因

查看数据库日志,报错:Can not open lib /usrlib64/libmyodbc5.so
在这里插入图片描述
手动查找libmyodbc5.so:find / -name libmyodbc5.so,找不到,但是可以找到libmyodbc5w.so
在这里插入图片描述
通过排查,原因是找不到/usrlib64/libmyodbc5.so

解决方法

建立软连接:ln -s /usr/local/mysql-odbc/lib/libmyodbc5w.so /usrlib64/libmyodbc5.so
在这里插入图片描述
再次使用dblink查远端表测试,无报错,问题解决
在这里插入图片描述

问题3:DBIINK远程服务器获取对象[xxx]失败,错误洋情[[FreeTDS][SQL Server]Could not find stored procedure ‘xxx’.]

使用dblink查SqlServer远端表测试,报错:DBIINK远程服务器获取对象[xxx]失败,错误洋情[[FreeTDS][SQL Server]Could not find stored procedure ‘xxx’.]
在这里插入图片描述

问题分析&原因

查看数据库日志,报错:[FreeTDS][SQL Server]Could not find stored procedure ‘xxx’.]
在这里插入图片描述
使用isql -v 连接名连接SQLServer,连接不上(参考链接: Java ODBC连接SqlServer,FreeTDS/jtds 连接SqlServer)报错:[unixODBC][FreeTDS][SQL Server]Unable to connect to data source]
在这里插入图片描述
通过排查:操作系统找驱动配置文件odbcinst.ini和数据源DSN配置文件odbc.ini都默认找/etc目录下的,而原来安装在/usr/local/etc目录下

解决方法

把odbcinst.ini和odbc.ini文件拷贝到/etc目录下即可
在这里插入图片描述

参考链接

参考链接: 配置达梦dblink到sqlserver2012出现连接异常

参考链接: DM->DM通过ODBC方式创建DBLINK,报错DBLINK连接丢失

参考链接: 【有道云笔记】达梦与sqlserver之间dblink创建

参考链接: Java ODBC连接SqlServer,FreeTDS/jtds 连接SqlServer

问题4:远程操作符执行失败,错误详情[[FreeTDS] [SQLServerInvalid cursor state]

使用dblink查SqlServer远端表测试,报错:远程操作符执行失败,错误详情[[FreeTDS] [SQLServerInvalid cursor state],此类问题又分为两种情况:

  • 情况1:应用端执行报错,数据库端执行不报错
  • 情况2:应用端和数据库端执行均报错。

情况1:应用端执行报错,数据库端执行不报错

问题分析&原因

官方解释:管理工具默认只取前100行数据,如果超过100行,又未获取全部数据,再次执行报错无效的游标状态
在这里插入图片描述

解决方法

每次获取全部数据,或者加top 取前几行等

情况2:应用端和数据库端执行均报错。

问题分析&原因

  • 大部分报错集中出现在 情况1:应用端执行报错,数据库端执行不报错,但是也有少量dblink查询会出现情况2:应用端和数据库端执行均报错
  • 更有意思的是,在测试环境中不会出现这样的问题,而在正式环境中出现了,正式环境和测试环境数据库版本&驱动版本均一致

严重怀疑是否和哪个参数有关系?比对测试环境和正式环境的dm.ini文件,还真找到一个:
在这里插入图片描述

通过hint提示拼接SQL:

select  /*+ DBLINK_OPT_FLAG(509)*/ 
		字段1,字段2
from 	表1
where 	条件1
and 	条件2;

重新在应用端和数据库端执行,不会出现报错

解决方法

因为此参数为动态参数,执行执行命令修改:

SP_SET_PARA_VALUE (1,'DBLINK_OPT_FLAG',509);

在这里插入图片描述
再次使用dblink查远端表测试,无报错,问题解决

### 配置达梦数据库中的DBLink连接至Oracle #### 使用OCI接口配置DBLink 为了使达梦数据库能够通过DBLink访问Oracle数据库,推荐采用Oracle OCI(Oracle Call Interface)方式进行配置[^3]。 - **下载并安装Oracle客户端驱动** Oracle Instant Client 是实现这一目标所必需的组件之一。可以从指定网站获取适用于操作系统的最新版本Instant Client包,并按照说明完成安装过程。 - **创建监听器** 在Oracle端需建立一个监听程序来接收来自达梦数据库发出的数据请求。这通常涉及到编辑`listener.ora`文件以及启动监听服务[^5]。 - **修改tnsnames.ora文件** 此文件用于定义网络服务名与实际数据库实例之间的映射关系,在其中添加针对目标Oracle数据库的服务条目是必要的步骤之一。 ```bash # Example entry in tnsnames.ora file ORCL = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = oracle_host_ip)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = orcl_service_name) ) ) ``` - **在达梦侧执行SQL命令创建DBLink对象** 完成上述准备工作之后,可以在达梦环境中利用如下语句构建指向远程Oracle数据库链接: ```sql CREATE DATABASE LINK dblink_oracle CONNECT TO username IDENTIFIED BY password USING 'orcl'; ``` 此处`username`, `password`代表具有适当权限的Oracle账户凭证;而`'orcl'`则是之前于`tnsnames.ora`内设定好的网络服务名称[^4]。 --- #### ODBC方式配置DBLink 对于某些特定场景下可能更倾向于使用ODBC作为中间件来进行跨平台间通信,则可考虑基于此协议实施相应设置。 - **注册ODBC数据源** 参照相关文档指导,在操作系统层面建立起名为DM_TO_ORA_DSN的新DSN资源,确保其参数正确无误地指向待接入的目标Oracle服务器实例[^1]。 - **编写连接字符串** 构建适配当前环境变量条件下的完整连接串表达式,该字符串将被用来初始化后续所有经由本路径发起的操作指令集。 ```sql CREATE DATABASE LINK dblink_odbc CONNECT TO "SCHEMA" IDENTIFIED BY "PASSWORD" USING '(DESCRIPTION=(DRIVER={Microsoft ODBC for Oracle};SERVER=//oracle_server:port/service_name))' ``` 请注意替换掉模板里的占位符部分(`SCHEMA`,`PASSWORD`)为真实的值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值