1. 1 対多の 1 対多の関係マッピング設定 (1 対 1 のエンティティ マッピング ファイルで設定)
<br>
<!-- cascade属性:级联操作属性 save-update: 级联保存,保存客户时,级联保存客户关联的联系人 delete:级联删除,删除客户时,级联删除客户关联的联系人 all:级联保存+级联删除 --> <!-- inverse属性:设置是否不维护关联关系 true:不维护关联 false(默认值):维护关联 --><!-- 一对多 --><set name="linkMen" inverse="true" ><!-- 外键列名 --><key column="lkm_cust_id" ></key><!-- 该集合是一对多关系表达,关联的对象时linkman --><one-to-many class="LinkMan" /></set>
1 対多|多対 1 の関係の場合、冗長な SQL ステートメントを配置します。一般に、1 つを選択したパーティはメンテナンスを放棄し、inverse 属性を true に設定します。
2.多対 1 多対 1 の関係マッピング設定 (多パーティ エンティティ マッピングで設定) file)
<!-- cascade属性:级联操作属性 save-update: 级联保存,保存客户时,级联保存客户关联的联系人 delete:级联删除,删除客户时,级联删除客户关联的联系人 all:级联保存+级联删除 --> <!-- 没有inverse属性: 外键列所在实体,无法放弃维护关联关系. --><!-- 多对一 --><many-to-one name="customer" column="lkm_cust_id" class="Customer" ></many-to-one>
3.多対多の多対多関係マッピング設定
<!-- 多对多关系配置 table:中间表表名--> <!-- inverse属性:设置是否不维护关联关系 true:不维护关联 false(默认值):维护关联 --> <!-- cascade属性:级联操作属性 save-update: 级联保存,保存客户时,级联保存客户关联的联系人 delete:级联删除,删除客户时,级联删除客户关联的联系人 all: 级联保存+级联删除 --><set name="roles" table="sys_user_role" ><!-- 别人引用"我"的外键列名 --><key column="user_id" ></key><!-- 表达集合是多对多关系 class属性:表达我与谁是多对多 column属性:表达另外一个外键列名 --><many-to-many class="Role" column="role_id" ></many-to-many></set>
多対多関係では、保守関係を開始する当事者を 1 つ選択し、その中間テーブルを配置します例えば、商品と注文が多対多の関係にある場合、注文は商品を維持するか、メンテナンスを放棄するかをビジネスロジックに基づいて決定します。
以上がHibernate でのマルチテーブル マッピング関係設定の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。