一尘不染

HQL IN运算符,枚举数组ClassCastException

hibernate

这是我的简化课程和枚举。

class A
{
    @Enumerated (value = EnumType.STRING)
    AType type;
}

enum AType
{
    X,Y
}

如果我跑

query = FROM A a WHERE a.type = :type
query.setParameter("type", AType.X);

一切都很好,花花公子。

但是,如果我执行以下操作:

AType[] types = new AType[1];
types[0] = AType.X;
query = FROM A a WHERE a.type IN (:types)
query.setParameter("types", types);

我得到:

Lcom.src.AType; cannot be cast to java.lang.Enum

如果我做:

Enum[] types = new Enum[1];
types[0] = AType.X;
query = FROM A a WHERE a.type IN (:types)
query.setParameter("types", types);

我得到:

Ljava.lang.Enum; cannot be cast to java.lang.Enum

有任何想法吗?


阅读 229

收藏
2020-06-20

共1个答案

一尘不染

query.setParameterList("types", types);
                  ^--

这应该做。

2020-06-20