【问题标题】:Hibernate - how to map an EnumSetHibernate - 如何映射 EnumSet
【发布时间】:2011-01-25 01:30:40
【问题描述】:

我有一个颜色枚举

public enum color { GREEN, WHITE, RED } 

我有包含它的 MyEntity。

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

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

编辑: 顺便说一句,我正在寻找 hbm.xml 配置而不是 @CollectionOfElements 注释

【问题讨论】:

标签: java hibernate orm enums set


【解决方案1】:

我使用来自EnumSet mapping 线程的解决方案,该线程依赖于&lt;element column&gt; 的使用。您只需要一个带有 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)。

【讨论】:

    【解决方案2】:

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

    【讨论】:

    • 感谢您的回复。实际上我正在使用 XML 来映射我的 java 类,我想知道是否有一种简单的方法来实现同样的目标
    • CollectionOfElements 已弃用。 ElementCollection 替换了它。
    猜你喜欢
    • 2011-05-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-07-26
    • 1970-01-01
    • 2010-11-27
    相关资源
    最近更新 更多