gpt4 book ai didi

java - 无法解决JPQL :parameter problem by using FUNC()

转载 作者:行者123 更新时间:2023-12-01 19:02:15 24 4
gpt4 key购买 nike

好吧,简单来说,我已经完成了实际的 JPQL,没有首先使用任何参数,它看起来像这样。

SELECT count(dt) 
FROM transaction dt
WHERE dt.transactionType = 'TEST'
AND dt.date
BETWEEN FUNC('TO_DATE','01-2019','mm-yyyy')
AND FUNC('TO_DATE','02-2019','mm-yyyy')

这东西有效!但现在的问题是我需要将 transactionType 和日期作为参数,这就是它的样子

SELECT count(dt) 
FROM transaction dt
WHERE dt.transactionType = :transType
AND dt.date
BETWEEN FUNC('TO_DATE',:lastMonth,'mm-yyyy')
AND FUNC('TO_DATE',:nextMonth,'mm-yyyy')

所以对于 :transType 来说没问题,但是在这个 FUNC() 内部似乎我不应该像那样放置参数并且需要一些解决方法。我一直在谷歌搜索,但找不到任何结果。

错误是这样的

You have attempted to set a parameter value using a name of lastMonth,'mm-yyyy') that does not exist in the query string

如您所见,FUNC() 内部的参数携带了其后面的 FUNC() 参数。我错过了什么?请赐教。

最佳答案

确保您使用 setString 作为参数类型。

我总是在 JPA 中使用命名参数时遇到困难,具体取决于查询的创建方式 - 尝试使用序数参数,例如:?1 并按索引设置它们。

我会避免使用 FUNC,因为如果您不非常小心,它可能会带来一些重大开销。

关于java - 无法解决JPQL :parameter problem by using FUNC(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59618146/

24 4 0