首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我们可以在Hibernate上保持内部枚举吗?

我们可以在Hibernate上保持内部枚举吗?
EN

Stack Overflow用户
提问于 2014-09-26 17:12:28
回答 1查看 1.5K关注 0票数 4

我在类"UserType“中创建了一个内部枚举”DEPARTMENT_EXCLUSIVE“,用于确定用户的实例是BASIC、DEPARTMENT_EXCLUSIVE还是超级用户。下面是代码的一个片段:

代码语言:javascript
复制
public class User {

private String id, lastName, firstName, middleName, password;
private UserType userType;

public void setId(String id) {
    this.id = id;
}

public void setLastName(String lastName) {
    this.lastName = lastName;
}

public void setFirstName(String firstName) {
    this.firstName = firstName;
}

public void setMiddleName(String middleName) {
    this.middleName = middleName;
}

public void setPassword(String password) {
    this.password = Encryption.encrypt(password);
}

public void setUserType(UserType userType) {
    this.userType = userType;
}

public String getId() {
    return id;
}

public String getLastName() {
    return lastName;
}

public String getFirstName() {
    return firstName;
}

public String getMiddleName() {
    return middleName;
}

public String getPassword() {
    return password;
}

public UserType getUserType() {
    return userType;
}   

public enum UserType {

    BASIC, DEPARTMENT_HEAD, SUPERUSER;

}

}

现在,我想使用ORM将实例化的对象保存到我的MySQL数据库中。我在用Hibernate。下面是类标记中的Hibernate映射文件片段:

代码语言:javascript
复制
<id name="id" type="string" column="id"/>
    <property name="lastName" column="lastName" type="string" not-null="true"/>
    <property name="firstName" column="firstName" type="string"/>
    <property name="middleName" column="middleName" type="string"/>
    <property name="password" column="password" type="string" not-null="true"/>
    <property name="userType" column="userType" not-null="true">
        <type name="org.hibernate.type.EnumType">
            <param name="enumClass">com.fileManagement.dataDesign.User.UserType</param>
            <param name="type">12</param>
            <param name="useNamed">true</param>
        </type>
    </property>

我运行了一些测试,一个例外是抛出,告诉我们找不到枚举。下面是测试代码:

代码语言:javascript
复制
SessionFactory f = HibernateUtil.getSessionFactory();
    Session s = f.openSession();
    Transaction t = s.beginTransaction();
    User user = new User();
    user.setId("0090713");
    user.setLastName("Nocos");
    user.setFirstName("Warren");
    user.setMiddleName("Manlangit");
    user.setPassword("wang1234");
    user.setUserType(UserType.DEPARTMENT_HEAD);
    s.save(user);
    t.commit();
    s.close();
    f.close();

下面是异常堆栈跟踪的片段:

代码语言:javascript
复制
Caused by: org.hibernate.HibernateException: Enum class not found
at org.hibernate.type.EnumType.setParameterValues(EnumType.java:244)
at org.hibernate.type.TypeFactory.injectParameters(TypeFactory.java:131)
at org.hibernate.type.TypeFactory.custom(TypeFactory.java:214)
... 12 more
Caused by: java.lang.ClassNotFoundException: com.fileManagement.dataDesign.User.UserType
at java.net.URLClassLoader$1.run(URLClassLoader.java:372)
at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:360)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:340)
at org.hibernate.internal.util.ReflectHelper.classForName(ReflectHelper.java:171)
at org.hibernate.type.EnumType.setParameterValues(EnumType.java:241)
... 14 more

我试着将枚举作为外部类,它运行得很好,但由于设计选择,我真的想将它作为内部类放在"User“类中,因为它只在该类上使用。有可能这样做吗?如果是,怎么做?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-09-26 17:33:00

正如我的注释中提到的,尝试将映射文件中的enum类声明为:

com.fileManagement.dataDesign.User$UserType

通常,如果我们想访问Hibernate中的任何内部类,那么我们需要使用$符号。

票数 8
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26064853

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档