本文内容来自YashanDB官网【标题】YMP迁移达梦时,报错:查询出现异常 【问题分类】数据导入导出 【关键字】数据同步,YMP,评估,数据迁移,SQL报错 【问题描述】YMP迁移达梦时,在评估阶段出现报错:(查询出现异常,执行SQL为:......)
错误日志为:YMP-ERROR-2024-11-28-0.log 【问题原因分析】查询达梦数据库数据字典出现报错,需修改达梦参数配置,或者在YMP中使用HINT。 【解决/规避方法】 达梦执行以下SQL,修改系统参数配置:
sp_set_para_value(1, 'VIEW_FILTER_MERGING', 29);
-- 或者在业务sql中使用以下hint:
SELECT /*+VIEW_FILTER_MERGING(29)*/
sel.OWNER,
sel.NAME,
sel.TYPE,
sel.STATUS,
sel.TABLE_NAME
FROM
(
SELECT
a.OWNER,
a.INDEX_NAME AS NAME,
'INDEX' AS TYPE,
obj.STATUS,
a.TABLE_NAME
FROM
ALL_INDEXES a
JOIN
ALL_OBJECTS obj
ON
a.OWNER = obj.OWNER
AND a.TABLE_NAME = obj.OBJECT_NAME
WHERE
a.owner IN ('GDP7SZGCH_LH')
AND obj.OBJECT_TYPE = 'TABLE'
AND a.INDEX_TYPE != 'VIRTUAL'
AND NOT (
(a.TABLE_NAME LIKE 'BM$_%'
OR a.TABLE_NAME LIKE 'BMJ$_%'
OR a.TABLE_NAME LIKE 'MDRT$_%'
OR a.TABLE_NAME LIKE 'MLOG$_%'
OR
a.TABLE_NAME LIKE 'MTAB$_%'
OR a.TABLE_NAME LIKE 'MVIEW$_%'
OR a.TABLE_NAME LIKE 'MTRG$_%'
OR a.TABLE_NAME LIKE 'STAT$_%')
OR
(a.TABLE_NAME LIKE '%$ALOG'
OR a.TABLE_NAME LIKE '%$AUX'
OR a.TABLE_NAME LIKE '%$DAUX'
OR a.TABLE_NAME LIKE '%$RAUX'
OR
a.TABLE_NAME LIKE '%$ROT'
OR a.TABLE_NAME LIKE '%$UAUX')
)) sel
JOIN
ALL_IND_COLUMNS col
ON
sel.OWNER = col.INDEX_OWNER
AND sel.NAME = col.INDEX_NAME
AND sel.TABLE_NAME = col.TABLE_NAME
重新进行迁移即可。(已反馈YMP开发) 【影响范围】所有版本 【修复版本】-