资讯详情

GBASE 8A v953报错集锦33--exists 子查询中 having 包含外表的列计算结果出错

问题现象

exists 子查询中的 having 列计算结果中包含外观的错误:

create table dm_evt_boct36_c(cust_no varchar(16),amount

decimal(24,3),post_date varchar(8),ibk_no varchar(5));

create table ldm_savtxn_c(to_custom_no varchar(16),post_date

varchar(8),cus_no varchar(34),trans_acct varchar(17),amount

decimal(24,3));

insert into dm_evt_boct36_c

values('0000000398926582',2000.20170102,40004

82',1500.20170102,40004;

insert into ldm_savtxn_c

values20170102年,0000003992682,00000398900686,90035000182100

06',-

500.000),9003500003992682,20170102,00000398900686,

21006',-300.000);

select boct.*

from dm_evt_boct36_c boct

where cust_no='0000000398926582' and exists

(select sum(-sav.amount) from ldm_savtxn_c sav where

sav.to_custom_no=boct.cust_no and sav.cus_no <>boct.cust_no group by

sav.trans_acct having sum(-sav.amount)/abs(boct.amount) >=0.2 and sum(-

sav.amount)/ abs(boct.amount) <=1.2);

解决方法:

exists 子查询优化的逻辑是将子查询修改为子查询和外观 join,但是 having 中

外表列存在,group by 如果没有,就会出现格 group by,这样出现的结果集是

不 固 定 的 , 优 化 无 法 支 持 。所以 在 新 的 版 本 中 屏 蔽

correlated_subselect_auto_optimize =1 时,exists 子查询中的 having 包含外

表列时,不要优化。确保结果集正确。

所以在 9.5.2.30、8.6.2.43R29、9.5.3.18 在版本中,子查询 having 包括外表和

内部表的列 , 且

group by

为 不 固 定 列 时 , 参 数

correlated_subselect_auto_optimize=1.关闭参数处理.结果一致,gnode

层 trace 日志显示#can't optimize this subselect because OUTER JOIN or

"outer select's table is used in having" or ... !

标签: 三相电压变送器sav

锐单商城拥有海量元器件数据手册IC替代型号,打造 电子元器件IC百科大全!

锐单商城 - 一站式电子元器件采购平台