検索

Hibernate之1-N关联映射

Jun 07, 2016 pm 04:09 PM
hibernate協会マッピング

一、Hibernate之1-N关联映射 1. 哪边是 1 , 哪边是多 ? 需要从业务的角度来说明。例如,Employee 和 Department 之间就是 n-1 的关联关系,Order 和 Customer 之间也是 n-1 的关联关系。 1). 关联关系是有方向的: 2). 如何在类中来建立关联关系呢 ? 解:

一、Hibernate之1-N关联映射

1. 哪边是 1 , 哪边是多 ?

需要从业务的角度来说明。例如,Employee 和 Department 之间就是 n-1 的关联关系,Order 和 Customer 之间也是 n-1 的关联关系。

1). 关联关系是有方向的:
\ 2). 如何在类中来建立关联关系呢 ? 解:通过成员变量的方式即可.

2. 单向 n-1 关联关系

1). 域对象中,在 Order 中声明一个 Customer 类型的成员变量,并提供 setter、getter

public class Order {

private Integer Z喎?http://www.2cto.com/kf/ware/vc/" target="_blank" class="keylink">vcmRlcklkOzxicj4KICAgICAgICAgIHByaXZhdGUgU3RyaW5nIG9yZGVyTmFtZTs8YnI+CiAgICAgPGJyPgogICAgICAgICAgcHJpdmF0ZSBDdXN0b21lciBjdXN0b21lcjs8YnI+Cjxicj4KICAgICAgICAgIC8vLi4uPGJyPgogICAgIH08YnI+Cjxicj4KMqOpLiDK/b7dse2jujxicj4KPGltZyBzcmM9"http://www.2cto.com/uploadfile/Collfiles/20141107/2014110709203821.png" alt="\">


3). 如何进行映射:通过 many-to-one 来映射

①. 注意:需要映射在 ORDERS 数据表中的外键列!

column="CUSTOMER_ID"
class="Customer">


4). API 操作时
①. save 时,若先保存 Order, 在保存 Customer,则会多出 UPDATE 语句;若先保存 Customer,再保存 Order,则只有 INSERT. 建议先保存 1 的一端的对象

②. get 时,
◆默认情况下,关联对象采取 懒加载 策略。即在获取 Order 时,若不使用关联的 Customer 的属性, 则不加载 Customer 对象
◆有懒加载就可能会发生懒加载异常:org.hibernate.LazyInitializationException。 ◇什么时候出现懒加载异常? 获取一个对象,没有初始化其关联的属性,若在 Session 已经关闭的情况下,访问关联的属性,就会抛出懒 加载异常。

③. update 时,
◆若对象本身是一个持久化对象,则在 flush Session 时,会级联更新其关联的对象的属性。
◆若对象是游离对象,则不会更新关联对象的属性。但可以通过设置 cascade 属性来使其能够进行更新

④. delete 时,
◆删除对象,只需要 ID 属性
◆防止发生外键约束异常

3. 单向 1-n 关联关系

1). 域对象:增加集合属性

public class Customer {

private Integer customerId;
private String customerName;

//访问 n 的一端的集合属性
private Set orders = new HashSet();

//....
}

注意:
①. 当 Session 从数据库中加载 Java 集合时, 创建的是 Hibernate 内置集合类的实例,
因此在持久化类中定义集合属性时必须把属性声明为 Java 接口类型
②. 在定义集合属性时, 通常把它初始化为集合实现类的一个实例.
避免应用程序访问取值为 null 的集合的方法抛出 NullPointerException


2).关系数据模型
\

3). 如何进行映射,在Customer.hbm.xml中通过 set 元素

order-by="ORDER_NAME ASC">




4). API 具体操作:

①. save 时:因为由 1 的一端来维护关联关系,所以一定会多出 UPDATE 语句! 最好不是有 1 的一端来维护关联关系
②. update 时:
◆若把集合对象 clear,默认情况下是把多的一端的外键置空
③. delete 时:可以删除 1 的一端,但是把多的一端的外键置空

5). set 的 order-by 属性:可以指定在查询集合时,按集合元素对应的数据表的列进行排序!

order-by="ORDER_NAME ASC">








----------------------------------------------------双向关联映射-----------------------------------------------------
4. 双向 1-n 关联关系

1). 如何进行映射(下面是Customer表,注意两者之间的对应关系)



2). set 元素的 inverse 属性可以指定由哪一方来维护关联关系, 一般地,在双向 1-n 关联关系中,1 的一端的 set 的 inverse 都设置为 true,表示有 n 的一端来维护关联关系!
◆ 比如说在Customer表中:
order-by="ORDER_NAME ASC" inverse="true">



声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
MySQLの役割:WebアプリケーションのデータベースMySQLの役割:WebアプリケーションのデータベースApr 17, 2025 am 12:23 AM

WebアプリケーションにおけるMySQLの主な役割は、データを保存および管理することです。 1.MYSQLは、ユーザー情報、製品カタログ、トランザクションレコード、その他のデータを効率的に処理します。 2。SQLクエリを介して、開発者はデータベースから情報を抽出して動的なコンテンツを生成できます。 3.MYSQLは、クライアントサーバーモデルに基づいて機能し、許容可能なクエリ速度を確保します。

MySQL:最初のデータベースを構築しますMySQL:最初のデータベースを構築しますApr 17, 2025 am 12:22 AM

MySQLデータベースを構築する手順には次のものがあります。1。データベースとテーブルの作成、2。データの挿入、および3。クエリを実行します。まず、createdAtabaseおよびcreateTableステートメントを使用してデータベースとテーブルを作成し、InsertINTOステートメントを使用してデータを挿入し、最後にSelectステートメントを使用してデータを照会します。

MySQL:データストレージに対する初心者向けのアプローチMySQL:データストレージに対する初心者向けのアプローチApr 17, 2025 am 12:21 AM

MySQLは、使いやすく強力であるため、初心者に適しています。 1.MYSQLはリレーショナルデータベースであり、CRUD操作にSQLを使用します。 2。インストールは簡単で、ルートユーザーのパスワードを構成する必要があります。 3.挿入、更新、削除、および選択してデータ操作を実行します。 4. Orderby、Where and Joinは複雑なクエリに使用できます。 5.デバッグでは、構文をチェックし、説明を使用してクエリを分析する必要があります。 6.最適化の提案には、インデックスの使用、適切なデータ型の選択、優れたプログラミング習慣が含まれます。

MySQLは初心者に優しいですか?学習曲線の評価MySQLは初心者に優しいですか?学習曲線の評価Apr 17, 2025 am 12:19 AM

MySQLは初心者に適しています。1)インストールと構成、2)リッチラーニングリソース、3)直感的なSQL構文、4)強力なツールサポート。それにもかかわらず、初心者はデータベースの設計、クエリの最適化、セキュリティ管理、データのバックアップなどの課題を克服する必要があります。

SQLはプログラミング言語ですか?用語を明確にするSQLはプログラミング言語ですか?用語を明確にするApr 17, 2025 am 12:17 AM

はい、sqlisaprogramginglanguagespecializedfordatamanamanagement.1)それはdeclarative、focusingonwhattoachieveratherthanhow.2)

酸性の特性(原子性、一貫性、分離、耐久性)を説明します。酸性の特性(原子性、一貫性、分離、耐久性)を説明します。Apr 16, 2025 am 12:20 AM

酸性属性には、原子性、一貫性、分離、耐久性が含まれ、データベース設計の基礎です。 1.原子性は、トランザクションが完全に成功するか、完全に失敗することを保証します。 2.一貫性により、データベースがトランザクションの前後に一貫性を保証します。 3.分離により、トランザクションが互いに干渉しないようにします。 4.永続性により、トランザクションの提出後にデータが永久に保存されることが保証されます。

MySQL:データベース管理システムとプログラミング言語MySQL:データベース管理システムとプログラミング言語Apr 16, 2025 am 12:19 AM

MySQLは、データベース管理システム(DBMS)であるだけでなく、プログラミング言語にも密接に関連しています。 1)DBMSとして、MySQLはデータを保存、整理、取得するために使用され、インデックスを最適化するとクエリのパフォーマンスが向上する可能性があります。 2)SQLとPythonに埋め込まれたプログラミング言語とSQLalchemyなどのORMツールを使用すると、操作を簡素化できます。 3)パフォーマンスの最適化には、インデックス、クエリ、キャッシュ、ライブラリ、テーブル分割、およびトランザクション管理が含まれます。

MySQL:SQLコマンドでデータの管理MySQL:SQLコマンドでデータの管理Apr 16, 2025 am 12:19 AM

MySQLはSQLコマンドを使用してデータを管理します。 1.基本コマンドには、select、挿入、更新、削除が含まれます。 2。高度な使用には、参加、サブクエリ、および集計関数が含まれます。 3.一般的なエラーには、構文、ロジック、パフォーマンスの問題が含まれます。 4。最適化のヒントには、インデックスの使用、Select*の回避、制限の使用が含まれます。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール