有关Quick BI中Case子句中多次使用lod函数返回空值问题分析

news2024/11/17 23:53:22

一、Quick BI中的lod_ include函数

lod_ include {维度1[,维度2]...:聚合表达式[:过滤条件]}

作用:将表达式中的维度一起作为分组依据进行订算。其中,

1)    维度1[,维度2]... :声明维度,指定聚合表达式要连接到的一个或多个维度。使用逗号分隔各个维度。

2)    聚合表达式:聚合表达式是所执行的计算,用于定义目标维度。

3)    过滤条件:可以通过对前面的声明维度设定条件进行过滤,非必须。

二、、问题描述

3月

4月

5月

合计

总结存数量

35116176

36286140

37120427

108522743

Quick BI数据集新建计算字段” 总结存数量=CASE WHEN MAX([月份])='3月' THEN lod_include{[月份]:SUM([结存数量]):[月份]='3月'}  WHEN MAX([月份])='4月' THEN lod_include{[月份]:SUM([结存数量]):[月份]='4月'}  WHEN MAX([月份])='5月' THEN lod_include{[月份]:SUM([结存数量]):[月份]='5月'} 。

END”

在Quick BI仪表板新建交叉表,以‘月份’为行,以‘总结存数量’为列,执行结果“数据返回为空“,这个结果显示不正确。

三、问题分析

查看SQL代码

SELECT

  LOD_TM.`LOD_2C07D23FC7BBAA` AS LOD_0,

  CASE

    WHEN LOD_TM.`temp_calculation_0` = '3月' THEN LOD_TP_0.`LOD_C5682C34D69BEC`

    WHEN LOD_TM.`temp_calculation_0` = '4月' THEN LOD_TP_1.`LOD_D78F97D23AEDC1`

    WHEN LOD_TM.`temp_calculation_0` = '5月' THEN LOD_TP_2.`LOD_5B3771E3CF7947`

  END AS LOD_1

FROM

  (

    SELECT

      ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA,

      MAX(ATN_T_1_.`月份`) AS temp_calculation_0

    FROM

      `terminaldata2`.`account` AS ATN_T_1_

    GROUP BY

      ATN_T_1_.`月份`

    ORDER BY

      LOD_2C07D23FC7BBAA ASC

    LIMIT

      0, 20

  ) AS LOD_TM

  INNER JOIN (

    SELECT

      LOD_TL.`LOD_2C07D23FC7BBAA` AS LOD_2C07D23FC7BBAA,

      LOD_TR.`LOD_measure_result` AS LOD_C5682C34D69BEC

    FROM

      (

        SELECT

          ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA

        FROM

          `terminaldata2`.`account` AS ATN_T_1_

        GROUP BY

          ATN_T_1_.`月份`

      ) AS LOD_TL

      INNER JOIN (

        SELECT

          SUM(

            ATN_T_1_.`结存数量`

          ) AS LOD_measure_result,

          ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA

        FROM

          `terminaldata2`.`account` AS ATN_T_1_

        WHERE

          ATN_T_1_.`月份` = '3月'

        GROUP BY

          ATN_T_1_.`月份`

      ) AS LOD_TR ON LOD_TL.`LOD_2C07D23FC7BBAA` = LOD_TR.`LOD_2C07D23FC7BBAA`

    GROUP BY

      LOD_TL.`LOD_2C07D23FC7BBAA`

  ) AS LOD_TP_0 ON LOD_TM.`LOD_2C07D23FC7BBAA` = LOD_TP_0.`LOD_2C07D23FC7BBAA`

  INNER JOIN (

    SELECT

      LOD_TL.`LOD_2C07D23FC7BBAA` AS LOD_2C07D23FC7BBAA,

      LOD_TR.`LOD_measure_result` AS LOD_D78F97D23AEDC1

    FROM

      (

        SELECT

          ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA

        FROM

          `terminaldata2`.`account` AS ATN_T_1_

        GROUP BY

          ATN_T_1_.`月份`

      ) AS LOD_TL

      INNER JOIN (

        SELECT

          SUM(

            ATN_T_1_.`结存数量`

          ) AS LOD_measure_result,

          ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA

        FROM

          `terminaldata2`.`account` AS ATN_T_1_

        WHERE

          ATN_T_1_.`月份` = '4月'

        GROUP BY

          ATN_T_1_.`月份`

      ) AS LOD_TR ON LOD_TL.`LOD_2C07D23FC7BBAA` = LOD_TR.`LOD_2C07D23FC7BBAA`

    GROUP BY

      LOD_TL.`LOD_2C07D23FC7BBAA`

  ) AS LOD_TP_1 ON LOD_TM.`LOD_2C07D23FC7BBAA` = LOD_TP_1.`LOD_2C07D23FC7BBAA`

  INNER JOIN (

    SELECT

      LOD_TL.`LOD_2C07D23FC7BBAA` AS LOD_2C07D23FC7BBAA,

      LOD_TR.`LOD_measure_result` AS LOD_5B3771E3CF7947

    FROM

      (

        SELECT

          ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA

        FROM

          `terminaldata2`.`account` AS ATN_T_1_

        GROUP BY

          ATN_T_1_.`月份`

      ) AS LOD_TL

      INNER JOIN (

        SELECT

          SUM(

            ATN_T_1_.`结存数量`

          ) AS LOD_measure_result,

          ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA

        FROM

          `terminaldata2`.`account` AS ATN_T_1_

        WHERE

          ATN_T_1_.`月份` = '5月'

        GROUP BY

          ATN_T_1_.`月份`

      ) AS LOD_TR ON LOD_TL.`LOD_2C07D23FC7BBAA` = LOD_TR.`LOD_2C07D23FC7BBAA`

    GROUP BY

      LOD_TL.`LOD_2C07D23FC7BBAA`

  ) AS LOD_TP_2 ON LOD_TM.`LOD_2C07D23FC7BBAA` = LOD_TP_2.`LOD_2C07D23FC7BBAA`



SELECT

  COUNT(1) AS query_count

FROM

  (

    SELECT

      LOD_TM.`LOD_2C07D23FC7BBAA` AS LOD_0,

      CASE

        WHEN LOD_TM.`temp_calculation_0` = '3月' THEN LOD_TP_0.`LOD_C5682C34D69BEC`

        WHEN LOD_TM.`temp_calculation_0` = '4月' THEN LOD_TP_1.`LOD_D78F97D23AEDC1`

        WHEN LOD_TM.`temp_calculation_0` = '5月' THEN LOD_TP_2.`LOD_5B3771E3CF7947`

      END AS LOD_1

    FROM

      (

        SELECT

          ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA,

          MAX(ATN_T_1_.`月份`) AS temp_calculation_0

        FROM

          `terminaldata2`.`account` AS ATN_T_1_

        GROUP BY

          ATN_T_1_.`月份`

      ) AS LOD_TM

      INNER JOIN (

        SELECT

          LOD_TL.`LOD_2C07D23FC7BBAA` AS LOD_2C07D23FC7BBAA,

          LOD_TR.`LOD_measure_result` AS LOD_C5682C34D69BEC

        FROM

          (

            SELECT

              ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA

            FROM

              `terminaldata2`.`account` AS ATN_T_1_

            GROUP BY

              ATN_T_1_.`月份`

          ) AS LOD_TL

          INNER JOIN (

            SELECT

              SUM(

                ATN_T_1_.`结存数量`

              ) AS LOD_measure_result,

              ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA

            FROM

              `terminaldata2`.`account` AS ATN_T_1_

            WHERE

              ATN_T_1_.`月份` = '3月'

            GROUP BY

              ATN_T_1_.`月份`

          ) AS LOD_TR ON LOD_TL.`LOD_2C07D23FC7BBAA` = LOD_TR.`LOD_2C07D23FC7BBAA`

        GROUP BY

          LOD_TL.`LOD_2C07D23FC7BBAA`

      ) AS LOD_TP_0 ON LOD_TM.`LOD_2C07D23FC7BBAA` = LOD_TP_0.`LOD_2C07D23FC7BBAA`

      INNER JOIN (

        SELECT

          LOD_TL.`LOD_2C07D23FC7BBAA` AS LOD_2C07D23FC7BBAA,

          LOD_TR.`LOD_measure_result` AS LOD_D78F97D23AEDC1

        FROM

          (

            SELECT

              ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA

            FROM

              `terminaldata2`.`account` AS ATN_T_1_

            GROUP BY

              ATN_T_1_.`月份`

          ) AS LOD_TL

          INNER JOIN (

            SELECT

              SUM(

                ATN_T_1_.`结存数量`

              ) AS LOD_measure_result,

              ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA

            FROM

              `terminaldata2`.`account` AS ATN_T_1_

            WHERE

              ATN_T_1_.`月份` = '4月'

            GROUP BY

              ATN_T_1_.`月份`

          ) AS LOD_TR ON LOD_TL.`LOD_2C07D23FC7BBAA` = LOD_TR.`LOD_2C07D23FC7BBAA`

        GROUP BY

          LOD_TL.`LOD_2C07D23FC7BBAA`

      ) AS LOD_TP_1 ON LOD_TM.`LOD_2C07D23FC7BBAA` = LOD_TP_1.`LOD_2C07D23FC7BBAA`

      INNER JOIN (

        SELECT

          LOD_TL.`LOD_2C07D23FC7BBAA` AS LOD_2C07D23FC7BBAA,

          LOD_TR.`LOD_measure_result` AS LOD_5B3771E3CF7947

        FROM

          (

            SELECT

              ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA

            FROM

              `terminaldata2`.`account` AS ATN_T_1_

            GROUP BY

              ATN_T_1_.`月份`

          ) AS LOD_TL

          INNER JOIN (

            SELECT

              SUM(

                ATN_T_1_.`结存数量`

              ) AS LOD_measure_result,

              ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAA

            FROM

              `terminaldata2`.`account` AS ATN_T_1_

            WHERE

              ATN_T_1_.`月份` = '5月'

            GROUP BY

              ATN_T_1_.`月份`

          ) AS LOD_TR ON LOD_TL.`LOD_2C07D23FC7BBAA` = LOD_TR.`LOD_2C07D23FC7BBAA`

        GROUP BY

          LOD_TL.`LOD_2C07D23FC7BBAA`

      ) AS LOD_TP_2 ON LOD_TM.`LOD_2C07D23FC7BBAA` = LOD_TP_2.`LOD_2C07D23FC7BBAA`

  ) AS a

以WHEN MAX([月份])='3月' THEN lod_include{[月份]:SUM([结存数量]):[月份]='3月'}为例分析:

上述代码,中LOD_TM表结果为

LOD_2C07D23FC7BBAA

temp_calculation_0

3月

3月

4月

4月

5月

5月

LOD_TL表结果为

LOD_2C07D23FC7BBAA

3月

4月

5月

LOD_TR表结果为

LOD_measure_result

LOD_2C07D23FC7BBAA

35116176

3月

LOD_TL与LOD_TR通过条件”ON LOD_TL.`LOD_2C07D23FC7BBAA` = LOD_TR.`LOD_2C07D23FC7BBAA`    GROUP BY  LOD_TL.`LOD_2C07D23FC7BBAA`”进行内连接(INNER JOIN)得到表LOD_TP_0,LOD_TP_0结果为:

LOD_2C07D23FC7BBAA

LOD_C5682C34D69BEC

3月

35116176

LOD_TM与LOD_TP_0通过条件“ON LOD_TM.`LOD_2C07D23FC7BBAA` = LOD_TP_0.`LOD_2C07D23FC7BBAA` “进行内连接(INNER JOIN),得到的结果为(这里称为表A1,由于是内连接,所以4月、5月无法显示):

LOD_2C07D23FC7BBAA

temp_calculation_0

LOD_C5682C34D69BEC(LOD_TP_0)

3月

3月

35116176

同理,当“WHEN MAX([月份])='4月' THEN lod_include{[月份]:SUM([结存数量]):[月份]='4月'}“,得到的结果为(这里称为表A2,由于是内连接,所以3月、5月无法显示):

LOD_2C07D23FC7BBAA

temp_calculation_0

LOD_C5682C34D69BEC(LOD_TP_1)

4月

4月

36286140

同理,当“WHEN MAX([月份])='5月' THEN lod_include{[月份]:SUM([结存数量]):[月份]='5月'}“,得到的结果为(这里称为表A3,由于是内连接,所以3月、4月无法显示):

LOD_2C07D23FC7BBAA

temp_calculation_0

LOD_C5682C34D69BEC(LOD_TP_2)

5月

5月

37120427

表A1、表A2、表A3默认进行通过字段‘LOD_2C07D23FC7BBAA‘进行内连接(INNER JOIN),由于表A1中只有’3月‘,表A2中只有’4月‘,表A3中只有’5月‘,内连接的表必然为空表。

四、优化建议

既然表A1、表A2、表A3之间默认是内连接(INNER JOIN),只需要让表A1、表A2、表A3中同时存在“3月“、”4月“、”5月“即可以。也就是把LOD_TM与LOD_TP_0通过条件“ON LOD_TM.`LOD_2C07D23FC7BBAA` = LOD_TP_0.`LOD_2C07D23FC7BBAA` “进行的内连接(INNER JOIN,改为左外连接(LEFT JOIN)。LOD_TP_1、LOD_TP_2同理进行相同操作。具体做法即将上述第43、101、159、261、319、377行代码由INNER JOIN 改为 LEFT JOIN。这样得到的表A1:

LOD_2C07D23FC7BBAA

temp_calculation_0

LOD_C5682C34D69BEC(LOD_TP_0)

3月

3月

35116176

4月

4月

NULL

5月

5月

NULL

表A2:

LOD_2C07D23FC7BBAA

temp_calculation_0

LOD_C5682C34D69BEC(LOD_TP_0)

3月

3月

NULL

4月

4月

36286140

5月

5月

NULL

表A3:

LOD_2C07D23FC7BBAA

temp_calculation_0

LOD_C5682C34D69BEC(LOD_TP_0)

3月

3月

NULL

4月

4月

NULL

5月

5月

37120427

新得到的表A1、表A2、表A3再进行内连接(INNER JOIN)得到的结果是:

LOD_2C07D23FC7BBAA

temp_calculation_0

LOD_C5682C34D69BEC(LOD_TP_0)

3月

3月

35116176

4月

4月

36286140

5月

5月

37120427

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1410824.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

加载服务端发送的模型文件_unity开发进阶

加载服务端发送的模型文件 前言一、服务端搭建二、unity请求文件三、加载模型结语 前言 之前我们学习制作的都是离线状态下的东西,今天我们学习制作一个小demo。 内容就是我们用unity请求后台,接受后台发送过来的模型,然后将模型加载到场景中…

面试题-【消息队列】

消息队列 问题1 如何进行消息队列的技术选型优点解耦 (pub/sub模型)异步(异步接口性能优化)削峰 使用消息队列的缺点几种消息队列的特性 问题2 引入消息队列之后该如何保证其高可用性RabbitMQ的高可用kafka高可用 问题3 在消息队列…

使用MMYOLO中yolov8训练自己VOC数据集实战

概述 MMYOLO是商汤公司基于PyTorch框架和YOLO系列算法开源的工具箱 - 目前支持的任务 目标检测旋转框目标检测 - 支持的算法 YOLOv5YOLOv6YOLOv7YOLOv8YOLOXRTMDetRTMDet-Rotated - 支持的数据集 COCO Dataset VOC Dataset CrowdHuman Dataset DOTA 1.0 Dataset 安装…

SpringBoot集成mybatis时idea控制台中文乱码问题解决

在application.yml中配置好映射文件打印数据库日志文件时,控制台出现乱码的情况解决如下 问题 在执行查询操作的时候,查询时可以查看是没有问题的,但是控制台乱码了 解决 在File-Setting-Editor-File Encodings中设置如图所示就可以了 现在…

【Web前端实操15】利用Grid布局完成九宫格

相关知识点: 创建多列 column-count 属性指定了需要分割的列数 列与列之间的间隙 column-gap 属性指定了列与列间的间隙 列边框 column-rule-style 属性指定了列与列间的边框样式 column-rule-width 属性指定了两列的边框厚度 column-rule-color 属性指定了…

解读《鸿蒙·NEXT星空版》华为注资70亿,将每月开发岗增涨10万+

​1月18日,鸿蒙生态千帆启航仪式正式开启。华为余承东说道:鸿蒙生态大势已定,满天星光,终汇成璀璨星河。 HarmonyOS NEXT鸿蒙星河版面向开发者开放申请。星河版将实现原生精致、原生易用、原生流畅、原生安全、原生智能、原生互联…

基于 Docker 搭建 Uptime-Kuma 一个极简风的应用监控

GitHub:https://github.com/louislam/uptime-kuma 一、uptime-kuma 介绍 Demo:https://uptime.wuhanjiayou.cn/ uptime-kuma 是一款开源的监控工具, 支持 TCP / PING / HTTP 等多种监控方式,可监测网站,数据库,Docker…

0125-2-Vue深入学习1—mustache模板引擎原理

[mustache] 是 “胡子”的意思&#xff0c;因为它的嵌入标记 {{ }} 旋转过来很像[胡子]&#xff0c;Vue中的 {{ }} 语法也引用了mustache&#xff0c;这也是我深入学习的目的。 1、原始js方式使 数据 变为视图 <ul id"list"></ul><script>var arr …

01-echarts如何绘制三维折线图

echarts如何绘制三维折线图 一、相关依赖包1、下载依赖2、引入依赖 二、创建图表盒子1、创建盒子2、定义数据3、编写方法1、初始化盒子2、设置配置项3、修改数据格式4、设置颜色数组4、设置name数组5、设置线三维和点三维6、添加配置项7、设置图表自适应 4、调用方法 三、整体代…

Oracle DG环境下的秘钥管理

今天有朋友问到1&#xff09;DG环境下的秘钥管理需要注意什么&#xff0c;2&#xff09;秘钥管理对DG的日志同步有影响吗&#xff1f; 对于2&#xff09;的回答是明确的&#xff0c;没有影响。秘钥的管理和DG的redo log shipping完全是两套机制。在最新版的Oracle Key Vault常…

线上版本升级 — — pg数据库备份

线上版本升级 — — pg数据库备份 在版本升级之前&#xff0c;我们通常为了保险都需要将数据库里的数据结构备份一份&#xff0c;防止升级失败之后数据丢失。&#xff08;根据业务而来&#xff0c;并非所有业务都需要备份&#xff09; 1 备份 1.1 pg_dump&#xff1a;备份指定…

Linux常见的管理命令

1. whoami 作用&#xff1a; 显示出当前有效的用户名称&#xff0c;Linux是多用户多任务 语法&#xff1a;whoami(选项) 选项&#xff1a; --help&#xff1a;在线帮助 --version&#xff1a;显示版本信息和退出 场景使用&#xff1a; 1. 当用户想要查看当前登录系统的用户…

04 约数

定义&#xff1a; 若整数n除以整数d的余数为0&#xff0c;即d能够整除n&#xff0c;n是d的倍数&#xff0c;记作d|n. 通过质因子求一个数的约数 如果n可以表示成 其中均为n的质因子 因为对于任意一个质因子都有选0个 选1个 选2个....选个共种可能&#xff0c; n的约数个数…

C++ STL库详解:list

目录 一、list简介 二、list的使用 2.1list的构造 2.2list iterator迭代器的使用 2.3list element access 2.4list 常见接口 2.5迭代器失效 三、list与vector的对比 一、list简介 1. list是可以在常数范围内在任意位置进行插入和删除的序列式容器&#xff0c;并且该容器…

腾讯云轻量应用服务器Docker如何一键搭建属于自己的幻兽帕鲁服务器?

幻兽帕鲁/Palworld是一款2024年Pocketpair开发的开放世界生存制作游戏&#xff0c;在帕鲁的世界&#xff0c;玩家可以选择与神奇的生物“帕鲁”一同享受悠闲的生活&#xff0c;也可以投身于与偷猎者进行生死搏斗的冒险。而帕鲁可以进行战斗、繁殖、协助玩家做农活&#xff0c;也…

【机器学习300问】19、深度学习和机器学习什么关系?

之前的文章都聚焦在传统的机器学习上&#xff0c;作为入门&#xff0c;学了许多机器学习的基础。往后的文章我会穿插着机器学习和深度学习的内容进行&#xff0c;所有有必要在这里先说下两者的关系。 一、从范围上讲 深度学习和机器学习都是人工智能的一个子领域&#xff0c;它…

杰理-修改蓝牙版本5.4

杰理-修改蓝牙版本5.4 #define BLUETOOTH_CORE_SPEC_54 0x0dextern void set_bt_version(u8 version); set_bt_version(BLUETOOTH_CORE_SPEC_54); //蓝牙版本5.4

Vscode配置python代码开发

文章目录 1. 配置python运行环境2. 常用插件说明3. Vscode配置文件说明3.1 setting.json配置说明3.2 launch.json配置说明 4. 远程开发5. 其他配置 1. 配置python运行环境 安装python插件&#xff1a;点击VSCode左侧边栏中的扩展图标&#xff08;或按 CtrlShiftX&#xff09;&a…

即时设计好用吗?即时设计都有什么优势?

即时设计是否易于使用&#xff1f;即时设计有哪些易于使用的功能&#xff1f;假如你在寻找一个免费的Sketch 或者网页版本 PS&#xff0c;那么「即时设计」这是个不错的选择。这个云端 UI 设计工具允许您在不占用计算机内存的情况下使用任何设备。它可以快速存储您的设计文件&a…

AI教我学编程之SQL Server常见指令以及数据类型

前言 今天在工作的过程中&#xff0c;遇到了许多常见的属性&#xff0c;在此做下记录&#xff0c;方便以后查询 目录 SQL Server 常见指令 对话AI 光有概念怎么行 阶段总结 SQL Server关键字 边学边练 数据类型 看图说话 对话AI 数据类型我知道 括号里的神秘数字 疑问 边练…