Hibernate - 如何映射EnumSet

时间:2010-03-08 16:34:44

标签: java hibernate orm enums set

我有一个Color Enum

public enum color { GREEN, WHITE, RED } 

我的MyEntity包含它。

public class MyEntity {
   private Set<Color> colors;
   ...

我已经有一个UserType来映射我的枚举 你知道如何在Hibernate hbm.xml中映射一组枚举吗?
我需要UserType还是最简单的方法?
谢谢

编辑:请注意,我正在寻找 hbm.xml 配置而不是@CollectionOfElements Annotation

2 个答案:

答案 0 :(得分:7)

我使用EnumSet mapping线程中的解决方案,该解决方案依赖于<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>

查询可能如下所示:

select distinct e from MyEntity e join e.colors colors where colors IN ('WHITE', 'GREEN')

整个解决方案适用于加载,保存和查询(对jasonab的信用)。

答案 1 :(得分:2)

您似乎需要使用@CollectionOfElements注释。该文件位于http://docs.jboss.org/hibernate/stable/annotations/reference/en/html_single/#entity-hibspec-collection-extratype,第2.4.6.2.5章。元素或复合元素的集合'。该示例还映射了一组枚举。