有关Quick BI中lod_fixed函数中以MAX()作为过滤条件报错

一、Quick BI中的lod_fixed函数

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

作用:使用指定维度进行计算而不引用任何其他维度。其中,

  1. 维度1[,维度2]...:声明维度,指定聚合表达式要连接到的一个或多个维度。使用逗号分隔各个维度。
  2. 聚合表达式聚合表达式是所执行的计算,用于定义目标维度。
  3. 过滤条件:可以通过对前面的声明维度设定条件进行过滤,非必须。

二、问题描述

quick bi数据集中新建计算字段“月度总结存数量= lod_fixed{[月份]:SUM([结存数量]):[月份]=MAX([月份])}

         在quick bi 仪表板中添加指标卡,并将“月度总结存数量”设为看板指标,结果数据查询失败。

报错详情

traceId:afe791fd-19fc-4928-b853-87066950cb28;

errMsg:数据源执行SQL失败:java.lang.RuntimeException: SQL execute error by datasource... java.sql.SQLException: Invalid use of group function com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:129) com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97) com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:122) com.mysql.cj.jdbc.StatementImpl.executeQuery(StatementImpl.java:1200) io.grpc.stub.ServerCalls$UnaryServerCallHandler$UnaryServerCallListener.onHalfClose(ServerCalls.java:182)

三、原因分析

查看quick bi中的SQL代码:

SELECTLOD_TP_0.`LOD_04537845B26433` AS LOD_0FROM(SELECT'-' AS T_ALA_2_FROM`terminaldata2`.`account` AS ATN_T_1_LIMIT0, 1) AS LOD_TMCROSS JOIN (SELECTSUM(LOD_TR.`LOD_measure_result`) AS LOD_04537845B26433FROM(SELECTATN_T_1_.`月份` AS LOD_2C07D23FC7BBAAFROM`terminaldata2`.`account` AS ATN_T_1_GROUP BYATN_T_1_.`月份`) AS LOD_TLINNER JOIN (SELECTSUM(ATN_T_1_.`结存数量`) AS LOD_measure_result,ATN_T_1_.`月份` AS LOD_2C07D23FC7BBAAFROM`terminaldata2`.`account` AS ATN_T_1_WHEREATN_T_1_.`月份` = MAX(ATN_T_1_.`月份`)GROUP BYATN_T_1_.`月份`) AS LOD_TR ON LOD_TL.`LOD_2C07D23FC7BBAA` = LOD_TR.`LOD_2C07D23FC7BBAA`) AS LOD_TP_0LIMIT0, 1

在SQL中由于where子句的执行顺序是在select子句的前面,所以不能将聚合函数直接用在where子句后面,而在第63~65行代码“WHERE ATN_T_1_.`月份` = MAX(ATN_T_1_.`月份`)这句代码中where子句中直接使用了聚合函数,所以会导致错误产生。 

四、优化建议

    虽然SQL中where子句后面不能直接跟聚合函数,但是可以通过子查询来解决,比如上面的代码“WHERE ATN_T_1_.`月份` = MAX(ATN_T_1_.`月份`)改为“WHERE  ATN_T_1_.`月份` = (SELECT MAX( `terminaldata2`.`account` .`月份`) FROM  `terminaldata2`.`account` )”,再执行就可以了。

五、总结

在SQL中where子句后面不能直接跟聚合函数,但是可以通过子查询,在子查询中使用聚合函数。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

WebSocket-黑马好客租房

文章目录 网站中的消息功能如何实现?什么是WebSocket?http与websocket的区别httpwebsocket 浏览器支持情况快速入门创建itcast-websocket工程websocket的相关注解说明实现websocket服务测试编写js客户端 SpringBoot整合WebSocket导入依赖编写WebSocketHa…

『 C++ - STL』map与set的封装 ( 万字 )

文章目录 🎡 map与set介绍🎡 map与set的基础结构🎡 红黑树的再修改🎠节点及树的定义🎠KeyOfValue的使用🎠插入函数🎠析构函数🎠红黑树完整代码(供参考) 🎡 迭代器的实现&…

QWidget: Must construct a QApplication before a QWidget 20:10:25: 程序异常结束。

如果你在Windows上混合并匹配了Release和Debug的dll,则会导致这种情况。我的链接的库是release的版本,也就是qwt.dll,但是点击Qt Creator的运行按钮默认是debug启动,所以报错了,Qt Creator运行按钮里选择release就可以…

SpringMVC搭建环境

idea创建java项目后添加webapp怎么配置 1.首先在main下创建一个普通文件webapp 2. 3.选中你的项目,添加Web 4.修改这两处的路径,修改为你webapp所在的路径 先修改左下角的路径,然后再添加web.xml. 然后再修改右上角的地址,注…

FaFu--练习复盘--2

3、函数练习 3.1、函数表达式(1) 描述 根据以下公式计算数学表达式的值,并将结果作为函数值返回。在main()函数中输入x,调用函数fun(x),并输出fun(x)的值。 输入 输入1行,包含1个double类型的浮点数&…

php array_diff 比较两个数组bug避坑 深入了解

今天实用array_diff出现的异常问题,预想的结果应该是返回 "integral_initiate">"0",实际没有 先看测试代码: $a ["user_name">"测","see_num">0,"integral_initiate&quo…

蓝桥杯练习题dfs与bfs

📑前言 本文主要是【算法】——dfs与bfs的文章,如果有什么需要改进的地方还请大佬指出⛺️ 🎬作者简介:大家好,我是听风与他🥇 ☁️博客首页:CSDN主页听风与他 🌄每日一句&#xff…

RabbitMQ与SpringAMQP

MQ,中文是消息队列(MessageQueue),字面来看就是存放消息的队列。也就是事件驱动架构中的Broker。(经纪人!) 1.RabbitMQ介绍 微服务间通讯有同步和异步两种方式 同步(通信&#xff0…

cluecumber-report-plugin生成cucumber测试报告

cluecumber为生成测试报告的第三方插件&#xff0c;可以生成html测报&#xff0c;该测报生成需以本地json测报的生成为基础。 所以需要在测试开始主文件标签CucumberOptions中&#xff0c;写入生成json报告。 2. pom xml文件中加入插件 <!-- 根据 cucumber json文件 美化测…

Git 配置与理解

简述 Git 在 Windows 和 Ubuntu 中的配置&#xff0c;以及对 Git 工作区域划分和 Git 中对于文件状态划分的理解。 git 基础安装与配置 基于 WSL 的 Ubuntu 下的 git 打开或关闭Windows功能 -> Hyper-V、Virtual Machine Platform、Windows Subsystem for Linux # 1.必须…

【好文翻译】JavaScript 中的 realm 是什么?

本文由体验技术团队黄琦同学翻译。 原文链接&#xff1a; https://weizmangal.com/2022/10/28/what-is-a-realm-in-js/ github仓库地址&#xff1a; https://github.com/weizman/weizman.github.io/blob/gh-pages/_posts/2020-02-02-what-is-a-realm-in-js.md 前言 作为我对…

【51单片机Keil+Proteus8.9】温室盆栽灌溉系统

实验五 实验名称 温室盆栽灌溉系统 软件设计&#xff1a; 1. 定义对应的引脚和端口的别名。 2. 编写延时函数&#xff0c;用于控制程序的执行速度。 3. 编写LCD控制函数&#xff0c;包括发送命令和发送数据两种操作。 4. 编写显示函数&#xff0c;用于在LCD上显示字符串…