0

Hyperjaxb を使用して JPA マッピングを生成しています。次に、hibernate3-maven-plugin を使用してデータベースの SQL スクリプトを生成します。私の問題は、次のように定義されたプロパティを持つ型があるという事実にあります。

<xsd:element name="priority" type="xsd:boolean"/>

SQLスクリプトは、次のように列を定義します

PRIORITY bit,

そして、JPAエンティティはそれを次のように定義します

/**
 * Obtient la valeur de la propriété priority.
 * 
 */
@Basic
@Column(name = "PRIORITY")
public boolean isPriority() {
    return priority;
}

/**
 * Définit la valeur de la propriété priority.
 * 
 */
public void setPriority(boolean value) {
    this.priority = value;
}

バックエンドとして MySql を使用しています。JPA/Hibernate entityManager がデータベースに対して JPA モデルを検証しようとすると、問題が発生します。次に、このエラーが発生します

org.hibernate.HibernateException: Wrong column type in custom.sample_type for column PRIORITY. Found: bit, expected: boolean

このエラーを修正するにはどうすればよいですか? どこかで読んだところ、Javaコードでこのようなことができる

@Basic
@Column(name = "B", columnDefinition = "BIT", length = 1)
public boolean isB() {
    return b;
}

しかし、私の JPA Java コードは Hyperjaxb によって自動生成されます。

4

1 に答える 1

1

免責事項:私はHyperjaxbの作成者です。

プロパティを次のようにカスタマイズしてみます。

<hj:basic>
  <orm:column column-definition="..."/>
</hj:basic>

カスタマイズ スキーマとそれが使用するORM スキーマを参照してください。

すべてのブール値をカスタマイズしたくない場合は、タイプごとのカスタマイズを構成することもできます (これはおそらく望ましくありません)。

<hj:default-single-property type="xsd:boolean">
    <hj:basic>
        <orm:column column-definition="..."/>
    </hj:basic>
</hj:default-single-property>   

<hj:default-collection-property type="xsd:boolean">
    <hj:element-collection>
        <orm:column column-definition="..."/>
    </hj:element-collection>
</hj:default-collection-property>

次のバインディング ファイルのを参照してください。

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<jaxb:bindings
    version="2.1"
    xmlns:jaxb="http://java.sun.com/xml/ns/jaxb"
    xmlns:xs="http://www.w3.org/2001/XMLSchema"
    xmlns:hj="http://hyperjaxb3.jvnet.org/ejb/schemas/customizations"
    xmlns:orm="http://java.sun.com/xml/ns/persistence/orm"
    xmlns:annox="http://annox.dev.java.net"
    jaxb:extensionBindingPrefixes="hj orm annox">

    <jaxb:bindings schemaLocation="schema.xsd" node="/xs:schema">
        <jaxb:schemaBindings>
            <jaxb:package name="org.jvnet.hyperjaxb3.ejb.tests.pocustomized"/>
        </jaxb:schemaBindings>
        <hj:persistence>
            <hj:default-generated-id name="MySuperId" transient="true">
                <orm:column name="MY_SUPER_ID"/>
            </hj:default-generated-id>
            <hj:default-one-to-many>
                <orm:join-table/>
            </hj:default-one-to-many>
        </hj:persistence>
        <jaxb:bindings node="xs:complexType[@name='one']/xs:sequence/xs:element[@name='many-to-many-join-table']">
            <annox:annotate>
                <annox:annotate annox:class="org.hibernate.annotations.Cascade" value="DELETE_ORPHAN"/>
            </annox:annotate>
        </jaxb:bindings>

        <jaxb:bindings node="xs:element[@name='ten']/xs:complexType">
            <hj:basic name="content">
                <orm:column length="1024"/>
            </hj:basic>
        </jaxb:bindings>

    </jaxb:bindings>


</jaxb:bindings>

hj:default-...-property要素を の中に配置する必要がありますhj:persistence。その後、デフォルトのマッピングをオーバーライドします。

于 2015-10-06T05:17:33.177 に答える