我意识到我错过了一些明显的东西。不确定它是什么,希望有人帮我看看我没看到的东西。
我的公司从映射文件开始,并生成架构和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
有些人可以指出我正在尝试做的事情。
感谢您帮助我学习......
答案 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>