Hibernate - 如何映射EnumSet

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

Pas*_*ent 7

我使用依赖于使用的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的信用).