簡體   English   中英

Querydsl - 如何獲取列的總和

[英]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 文檔:

https://querydsl.com/static/querydsl/latest/apidocs/com/querydsl/core/types/dsl/NumberExpression.html

我目前沒有在本地設置 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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM