0

クライアントのmssqlデータベースに2つのテーブルがあります。1つ目はジョブテーブルです。ロードタイプとロードウェイトなどを含むジョブエンティティを作成しましたが、正常に機能します。

私の問題は、ロードポイントとアンロードポイントに関する情報を含む2番目のテーブルがあることです。2番目のテーブル(私はJEPと呼んでいます)には、タイプ(ロードまたはアンロード)、郵便番号、および顧客番号のいくつかの項目で構成される主キーがあります。

エンティティJobEndPointを作成し、NetBeansは、そのすべてのフィールドを含む主キーJobEndPointPKを表すオブジェクトも作成しました。

Jobエンティティに2つのJobEndPoint(loadPointとunloadPoint)を追加したいと思います。私の問題は今です:Hibernateでどのように注釈を付けるのですか?私の意見では、それは@OneToOneリレーションシップです。... "のようなSELECTステートメントを指定できれば完璧ですSELECT * FROM JEP WHERE type="load" AND customer_nr="123" AND zip_code="123。それはHibernateで可能ですか?

ご協力いただきありがとうございます!

よろしく、

マルコ


エンティティは次のとおりです。

@Entity
@Table(name = "Auftragsdaten", catalog = "...", schema = "dbo")
public class Job implements Comparable<Object>, Serializable {

    private static final long serialVersionUID = 4285871251915951149L;

    @Id
    @Basic(optional = false)
    @Column(name = "`id`", nullable = false)
    int id;

    @Column(name = "`AufNr`", nullable=false)
    int jobId;

    @Transient
    List<Integer> jobsAdded;

    @Column(name = "`Beladedatum`", nullable=false)
    @Temporal(TemporalType.DATE)
    Date loadDate;

    @Column(name = "`Beladezeit`")
    @Temporal(TemporalType.TIME)
    Date loadTimeFrom;

    @Transient
    Date loadTimeTo;

    @Column(name = "`Entladedatum`", nullable=false)
    @Temporal(TemporalType.DATE)
    Date unloadDate;

    @Column(name = "`Entladezeit Beginn`")
    @Temporal(TemporalType.TIME)
    Date unloadTimeFrom;

    @Column(name = "`Entladezeit Ende`")
    @Temporal(TemporalType.TIME)
    Date unloadTimeTo;

    @Transient
    List<JobEndPoint> froms;

    @OneToOne
    @JoinColumns ({
        @JoinColumn(name="`Beladetyp`", referencedColumnName = "`Ladetyp`", insertable = false, updatable = false),
        @JoinColumn(name="`AbsNr`", referencedColumnName = "`KundenNr`", insertable = false, updatable = false),
        @JoinColumn(name="`Verkehrsart`", referencedColumnName = "`VerkArt`", insertable = false, updatable = false),
        @JoinColumn(name="`von LKZ`", referencedColumnName = "`LKZ`", insertable = false, updatable = false),
        @JoinColumn(name="`von PLZ`", referencedColumnName = "`PLZ`", insertable = false, updatable = false)
    })
    JobEndPoint fromPoint;

    @Transient
    JobEndPoint toPoint;

    @Column(name = "`Verkehrsart`", length = 10, nullable=false)
    @Enumerated
    JobType type;

    @Column(name = "`Anzahl Paletten CCG1`")
    int numberCCG1;

    @Column(name = "`Anzahl Paletten CCG2`")
    int numberCCG2;

    @Transient
    int numberFullContainer;

    @Transient
    int numberEmptyContainer;

    @Column(name = "`Anzahl Container`")
    int numberContainer;

    @Column(name = "`Anz Stellplätze`")
    int numberUnits;

    @Column(name = "`Bruttogewicht`", nullable=false)
    int loadWeight;

    @ManyToOne
    @JoinColumn(name="`Kühlkennzeichen`")
    CoolingCode coolingCode;
}

@Entity
@Table(name = "BES", catalog = "...", schema = "dbo")
public class JobEndPoint implements Serializable {

    private static final long serialVersionUID = 1017986852824783744L;

    @Id
    protected JobEndPointPK jobEndPointPK;

    (...)
}

@Embeddable
public class JobEndPointPK implements Serializable {

    @Basic(optional = false)
    @Column(name = "`Ladetyp`", nullable = false, length = 50)
    @Enumerated
    EndPointType type;

    @Basic(optional = false)
    @Column(name = "`KundenNr`", nullable = false)
    int customerId;

    @Basic(optional = false)
    @Column(name = "`VerkArt`", nullable = false, length = 10)
    @Enumerated
    JobType jobType;

    @Basic(optional = false)
    @Column(name = "`LKZ`", nullable = false, length = 3)
    String countryCode;

    @Basic(optional = false)
    @Column(name = "`PLZ`", nullable = false, length = 7)
    String zipCode;
}
4

1 に答える 1

0

一般に、複合キーの代わりに、生成された内部主キーを使用することをお勧めします。ただし、複合キーを使用する必要がある場合は、次のアイデアが役立つと思います。

これは識別子コンポーネントとして実装されていることを理解していJobEndPointPKます(Hibernateリファレンスの8.4章を参照)。equals注: Hibernateはこれらに依存しているため、hashCode`メソッドを正しく実装することが重要です。

更新:あなたのJobEndPointとが次のようにJobEndPointPK見える場合:

@Embeddable
class JobEndPointPK {
    @Column(name = "type", nullable = false)
    @Enumerated
    EndPointType type;

    @Column(name = "zipCode", nullable = false)
    String zipCode;

    @Column(name = "customerNumber", nullable = false)
    int customerId;

    // equals, hasCode, getters, setters etc.
}

@Entity
class JobEndPoint {
    @Id
    private JobEndPointPK key;

    // getters, setters etc.
}

マッピングアノテーションは次のようになります。

@Entity
class Job {
    @OneToOne
    @JoinColumns ({
        @JoinColumn(name="loadPointType", referencedColumnName = "type"),
        @JoinColumn(name="loadPointZip", referencedColumnName = "zipCode"),
        @JoinColumn(name="loadPointCust", referencedColumnName = "customerNumber")
    })
    private JobEndPoint loadPoint;
    // similarly for unloadPoint
    // other properties
}

例はここから適応されます。

JobEndPointPK.typeただし、どうすればよいかわかりません。loadPoint明らかに、、Loadについてです。そのためunloadPointUnloadDBに個別に保存することはおそらく望ましくありません。アノテーションで値を指定できると思いますが、@Formula具体的な例は見たことがありません。

このコードはすべて純粋に実験的なものであり、私はテストしていません。

テーマには他にもバリエーションがあります。詳細については、「Hibernateを使用したJavaPersistence」の第8章の「アノテーション付きの複合キー」のセクションを参照してください。

于 2010-02-20T13:13:48.470 に答える