1

我有角色实体类:

@Entity
public class Role extends Model {

    @Id
    @Constraints.Required
    public Integer id;

    @Constraints.Required
    @Formats.NonEmpty
    @Enumerated(EnumType.STRING)
    public RoleNameEnum name; // name is enum value
}

在一些测试中,我尝试按角色查找用户:

List<User> users = User.findByRole(Role.findByRoleName(RoleNameEnum.ADMIN));

其中方法findByRoleName()如下:

public static List<User> findByRole(Role role) {
    return find.where().eq("role", role).findList();
}

我收到错误:

[error] Test UserTest.findUsersByRole failed: No ScalarType registered for class models.Role
[error]     at com.avaje.ebeaninternal.server.persist.Binder.bindObject(Binder.java:183)
[error]     at com.avaje.ebeaninternal.server.query.CQueryPredicates.bind(CQueryPredicates.java:162)
[error]     at com.avaje.ebeaninternal.server.query.CQuery.prepareBindExecuteQuery(CQuery.java:413)
[error]     at com.avaje.ebeaninternal.server.query.CQueryEngine.findMany(CQueryEngine.java:198)
[error]     at com.avaje.ebeaninternal.server.query.DefaultOrmQueryEngine.findMany(DefaultOrmQueryEngine.java:104)
[error]     at com.avaje.ebeaninternal.server.core.OrmQueryRequest.findList(OrmQueryRequest.java:344)
[error]     at com.avaje.ebeaninternal.server.core.DefaultServer.findList(DefaultServer.java:1469)
[error]     at com.avaje.ebeaninternal.server.querydefn.DefaultOrmQuery.findList(DefaultOrmQuery.java:906)
[error]     at com.avaje.ebeaninternal.util.DefaultExpressionList.findList(DefaultExpressionList.java:201)
[error]     at models.User.findByRole(User.java:63)
[error]     at UserTest$4.run(UserTest.java:62)
[error]     at play.test.Helpers.running(Helpers.java:294)
[error]     at UserTest.findUsersByRole(UserTest.java:58)

有人知道可能是什么问题吗?

4

2 回答 2

4

最快的解决方案,假设您映射 EnumValue 与枚举名称完全相同:

public enum RoleNameEnum {
    @EnumValue("REGULAR")
    REGULAR,
    @EnumValue("ADMIN")
    ADMIN
}

然后你可以实现 findByRole 方法如下:

public static List<User> findByRole(Role role) {
    return find.where().eq("role", role.name()).findList();
}

其中魔术只是使用映射的字符串值而不是角色名称的枚举实例。

我在 ebean 问题跟踪器上发布了一个错误:http ://www.avaje.org/bugdetail-427.html,binder应该检测枚举对象并将其自动解释为它的映射值。

编辑:

如果您需要除了简单枚举值之外的其他映射,这里是使用 @EnumValue 注释获取值集的实用程序代码

public static <T extends Enum<T>> String serialize(T theEnum) {
    try {
        for (Field f : theEnum.getDeclaringClass().getDeclaredFields()) {
            if (theEnum.equals(f.get(theEnum))) {
                EnumValue enumValue = f.getAnnotation(EnumValue.class);
                if (enumValue != null)
                    return enumValue.value();
            }
        }
    } catch (Exception e) {
    }
    return null;
}

然后你可以使用 serialize 方法实现 findByRole

public static List<User> findByRole(Role role) {
    return find.where().eq("role", serialize(role)).findList();
}
于 2012-09-26T14:37:16.837 回答
2

看起来问题是您有一个角色列表,而不是您的用户的单个属性。

@Constraints.Required
@ManyToMany
public List<Role> roles = new ArrayList<Role>();

要查询该列表,请尝试:

public static List<User> findByRole(Role role) {
    return find.where().in("roles", role).findList();
}
于 2012-12-22T07:05:03.570 回答