0

我有一个 xsd 文件,其中包含一个具有枚举约束的元素:

<xs:complexType name="Request">
    <xs:sequence>
        <xs:element name="CommsAddress" type="xs:string" />
        <xs:element name="CommsAddressType">
            <xs:simpleType>
                <xs:restriction base="xs:string">
                    <xs:enumeration value="EMAIL"/>
                    <xs:enumeration value="PHONE"/>
                </xs:restriction>
            </xs:simpleType>
        </xs:element>
        ...

我希望CommsAddressType生成的 Java 类中的字段是生成的枚举,其值EMAILPHONE. 反过来,我希望 Hibernate 自动生成我的数据库模式,其中包含一个CommsAddressType包含两行值EMAILPHONE. 然后该Request表可以简单地用一CommsAddressTypeId列引用这些。

目前,Hyperjaxb3使用type 字段生成我的Request类:CommsAddressTypeString

@XmlElement(name="CommsAddressType")
protected String commsAddressType

并生成模式,以便Request表具有CommsAddressTypetype 列VARCHAR。这显然会导致大量不必要的重复数据。

有什么方法可以实现我上面描述的吗?此外,当我向客户公开 xsd 时,我想尽可能避免在架构中包含任何 jaxb 或 hyperjaxb 标记。

4

1 回答 1

0

免责声明:我是Hyperjaxb的作者。

如果您将枚举类型变成 Java 中的枚举,Hyperjaxb 会将它们作为枚举而不是字符串来处理。为此,例如,您可以使用以下方法自定义您的简单类型:

<jaxb:typesafeEnumClass/>

请参阅此示例

Hyperjaxb 会将相应的属性映射为@Enumerated.

不,您不能生成查找表,但您可以自定义枚举在数据库中的映射方式。例如,您可以将其映射为EnumType.ORDINAL

<hj:basic><orm:enumerated>ORDINAL</orm:enumerated></hj:basic>

例子

实际上,使用枚举,您实际上并不需要 JPA 的查找表。JPA 将根据指定的映射正确映射枚举EnumType

但是您可能需要一个用于您自己目的的查找表 - 例如能够在连接查询中生成人类可读的值。

在这种情况下,我建议将枚举映射为ORDINAL并在您自己的 DDL 脚本中添加一个查找表和相应的外键。

是的,您可以在单独的绑定文件(通常bindings.xjb)中进行所有描述的自定义,而不必直接在模式中进行。在这里查看测试项目,有很多例子。只需*.xjb在目录中查找文件src/main/resources

于 2015-10-28T10:18:00.353 回答