[英]Querydsl - How to get sum of columns
以下是我的库存表信息
id, bigint(20)
available_quantity, int(11)
allocation_quantity, int(11)
stop_quantity, int(11)
damage_quantity, int(11)
standby_quantity, int(11)
我想做一个查询,而不是在 sql 它是:
SELECT
available_quantity,
allocation_quantity,
stop_quantity,
damage_quantity,
standby_quantity,
available_quantity + allocation_quantity + standby_quantity
FROM STOCK
我尝试寻找解决方案,但我得到的最接近的是:
return queryFactory
.select(new QStockResponseDto(
stock.availableQuantity,
stock.standbyQuantity,
stock.allocationQuantity,
stock.availableQuantity + stock.standbyQuantity + stock.allocationQuantity
)).from(stock)
但这表明以下错误
Operator '+' cannot be applied to 'com.querydsl.core.types.dsl.NumberPath<java.lang.Integer>', 'com.querydsl.core.types.dsl.NumberPath<java.lang.Integer>'
我不知道如何在 QueryDSL 中获得这个“available_quantity + allocation_quantity + standby_quantity”:
错误消息为您提供了有关该问题的重要提示。 值 stock.availableQuantity、stock.standbyQuantity 和 stock.allocationQuantity 都是 NumberExpression 类型的对象。 在此处阅读 NumberExpression 文档:
我目前没有在本地设置 QueryDSL 来验证这一点,但我认为您只需要替换:
stock.availableQuantity + stock.standbyQuantity + stock.allocationQuantity
有了这个:
stock.availableQuantity.add(stock.standbyQuantity).add(stock.allocationQuantity)
如果您需要为该结果提供别名,请在第二个 add() 方法之后附加 .as(Path<>) 方法。 让我们知道这是否有效。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.