Hibernate映射持久化枚举字符串

时间:2012-04-20 23:04:57

标签: hibernate hibernate-mapping

我意识到我错过了一些明显的东西。不确定它是什么,希望有人帮我看看我没看到的东西。

我的公司从映射文件开始,并生成架构和java文件。

我想弄清楚如何映射。我有一个表的列,在有限数量的字符串上只能有1个:       'DOES_NOT_EXIST','NEW,INITIATILIZE','RUNNING','TEARDOWN'

TABLE STATE_MACHINE
    ....
    STATE VARCHAR2(32)
.....


public enum StatEnum {
    DOES_NOT_EXIST, NEW,INITIATILIZE, RUNNING, TEARDOWN
}

我们想要做的事情是

StateMachine machine = new StateMechine();
machine.state=StatEnum.NEW;
....
Persistance.save(machine)

问题是我收到“无法提交事务:无法执行JDBC批量更新:ORA-00932:不一致的数据类型:预期BINARY获得NUMBER”

我认为HBM映射文件应该是符合的                           com.foo.StateEnum             12              

有些人可以指出我正在尝试做的事情。

感谢您帮助我学习......

1 个答案:

答案 0 :(得分:0)

我最终创建了一个实现EnhancedUserType和ParameterizedType的类。

在实现上述类的包中,我放置了我的枚举类。

我的Hibernate xml有

    <property name="state" column="state">
        <meta attribute="use-in-tostring">true</meta>
        <meta attribute="field-description">state types</meta>
        <type name="com.....h.core.domain.usertype.MyStrEnumUserType">
            <param name="enumClassname">com.......core.domain.usertype.StateTypeEnum</param>
        </type>
    </property>