mic*_*son 7 java orm enums hibernate set
我有一个彩色枚举
public enum color { GREEN, WHITE, RED }
Run Code Online (Sandbox Code Playgroud)
我有包含它的MyEntity.
public class MyEntity {
private Set<Color> colors;
...
Run Code Online (Sandbox Code Playgroud)
我已经有一个UserType来映射我的枚举.
你知道如何在Hibernate hbm.xml中映射一组枚举吗?
我需要UserType还是最简单的方法?
谢谢
编辑:请注意,我正在寻找hbm.xml配置而不是@CollectionOfElements Annotation
我使用依赖于使用的EnumSet映射线程的解决方案<element column>.你只需要一个带有id和字符串的表来映射集合(MYENTITY_COLOR这里).映射看起来就像那样(EnumUserType来自Java 5 EnumUserType的那个):
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<typedef name="color" class="com.stackoverflow.q2402869.EnumUserType">
<param name="enumClassName">com.stackoverflow.q2402869.Color</param>
</typedef>
<class name="com.stackoverflow.q2402869.MyEntity" entity-name="MyEntity" table="MYENTITY">
<id name="id" type="java.lang.Long">
<column name="ID" />
<generator class="assigned" />
</id>
<set name="colors" table="MYENTITY_COLORS">
<key column="ID" not-null="true"/>
<element type="color" column="COLOR"/>
</set>
</class>
</hibernate-mapping>
Run Code Online (Sandbox Code Playgroud)
查询可能如下所示:
select distinct e from MyEntity e join e.colors colors where colors IN ('WHITE', 'GREEN')
Run Code Online (Sandbox Code Playgroud)
整个解决方案适用于加载,保存和查询(jasonab的信用).
| 归档时间: |
|
| 查看次数: |
6768 次 |
| 最近记录: |