gpt4 book ai didi

java - 在实体中使用 Enum 时进行查询的问题

转载 作者:IT老高 更新时间:2023-10-28 13:51:54 26 4
gpt4 key购买 nike

我在问题实体中有以下内容:

@NamedQuery(name = "Question.allApproved",
query = "SELECT q FROM Question q WHERE q.status = 'APPROVED'")

@Enumerated(EnumType.STRING)
private Status status;

// usual accessors

我遇到了这个异常:

Exception Description: Error compiling the query [Question.countApproved: SELECT COUNT(q) FROM Question q WHERE q.status = 'APPROVED'], line 1, column 47: invalid enum equal expression, cannot compare enum value of type [myCompnay.application.Status] with a non enum value of type [java.lang.String]. at org.eclipse.persistence.internal.jpa.EntityManagerSetupImpl.deploy(EntityManagerSetupImpl.java:501)

我该如何解决这个问题?

最佳答案

我认为你应该使用你的(完全合格的)Status 枚举而不是文字值,所以像这样:(假设你的 Status 枚举在 com .myexample 包)

@NamedQuery(name = "Question.allApproved", 
query = "SELECT q
FROM Question q
WHERE q.status = com.myexample.Status.APPROVED").

关于java - 在实体中使用 Enum 时进行查询的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8217144/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com