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

目录

背景

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

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

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

问题分析&原因

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

解决方法

直接使用dblink查远端表测试

问题2:DBLINK连接丢失

使用dblink查MYSQL远端表测试,报错:DBLINK连接丢失

问题分析&原因

查看数据库日志,报错:Can not open lib /usrlib64/libmyodbc5.so

手动查找libmyodbc5.sofind / -name libmyodbc5.so,找不到,但是可以找到libmyodbc5w.so

通过排查,原因是找不到/usrlib64/libmyodbc5.so

解决方法

建立软连接:ln -s /usr/local/mysql-odbc/lib/libmyodbc5w.so /usrlib64/libmyodbc5.so

再次使用dblink查远端表测试,无报错,问题解决

问题3:DBIINK远程服务器获取对象xxx失败,错误洋情\[FreeTDSSQL ServerCould not find stored procedure 'xxx'.]

使用dblink查SqlServer远端表测试,报错:DBIINK远程服务器获取对象xxx失败,错误洋情\[FreeTDSSQL ServerCould not find stored procedure 'xxx'.]

问题分析&原因

查看数据库日志,报错:FreeTDSSQL ServerCould 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:

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

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

解决方法

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

javascript 复制代码
SP_SET_PARA_VALUE (1,'DBLINK_OPT_FLAG',509);

再次使用dblink查远端表测试,无报错,问题解决

相关推荐
GreatSQL几秒前
gt-checksum v4.0.0 新功能解读系列文章(1):断点续传——大任务中断不再从头跑
mysql
TDengine (老段)7 分钟前
TDengine 连接算子 — Inner/Outer/ASOF/Window Join 的实现与使用
大数据·数据库·物联网·哈希算法·时序数据库·tdengine·涛思数据
Keano Reurink23 分钟前
搜索API与GSC数据对比:发现数据盲区
数据库·python·数据挖掘
shushangyun_24 分钟前
汽车服务行业B2B平台+AI解决方案哪家专业:2026年最新测评
java·运维·网络·数据库·人工智能·汽车
大黄说说39 分钟前
深入理解 Go 协程 Goroutine:并发编程的核心精髓
java·数据库·python
sulikey1 小时前
数据库系统概论4 - 更新与视图 期末速成课笔记
数据库·笔记·考试·期末速成·数据库系统概论
锋行天下1 小时前
数据库安全并发控制详解:乐观锁 vs 悲观锁 vs 原子操作
前端·数据库·后端
2601_961875241 小时前
花生十三公考课程|网课|视频
数据库·windows·git·svn·eclipse·github
l1t2 小时前
DeepSeek总结的parquet Variant “碎形化“技术
数据库·parquet
铁打的阿秀2 小时前
SQL server2025 Express安装及管理工具安装使用教程(Windows)
windows·sqlserver·express