• 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.000,'20170102','40004'),('00000003989265
    82',1500.000,'20170102','40004');
    insert into ldm_savtxn_c GBase 8a MPP Cluster FAQ FAQ
    文档版本(2021-04-02) 南大通用数据技术股份有限公司
    72
    values('0000000398926582','20170102','0000000398900686','90035000183210
    06',-
    500.000),('0000000398926582','20170102','0000000398900686','90035000183
    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 ... !
  • 相关阅读:
    springboot单体项目如何拆分成微服务
    java排序算法
    如何修复 Windows 11/10上的 0x8007023e Windows 更新错误
    C语言 函数
    【mysql为什么采用b+树作为索引】
    java版工程管理系统Spring Cloud+Spring Boot+Mybatis实现工程管理系统源码
    Windows:Arm,我们不合适
    【NLP】基于神经网络PCNN(Piece-Wise-CNN)的关系抽取模型
    Jmeter使用
    微信小程序开源云开发的博客【点赞、收藏、评论、海报、签到、积分、后台管理等】
  • 原文地址:https://blog.csdn.net/m0_49291452/article/details/125540673