Hibernate 的關聯關係對映
需求分析
1. 因為客戶和聯絡人是一對多的關係,在有客戶的情況下,完成聯絡人的新增儲存操作
技術分析之Hibernate的關聯關係對映之一對多對映(重點)
1. JavaWEB中一對多的設計及其建表原則
2. 先匯入SQL的建表語句
* 建立今天的資料庫:create database hibernate_day03;
* 在資料中找到客戶和聯絡人的SQL指令碼
3. 編寫客戶和聯絡人的JavaBean程式(注意一對多的編寫規則)
* 客戶的JavaBean如下
public class Customer {
private Long cust_id;
private String cust_name;
private Long cust_user_id;
private Long cust_create_id;
private String cust_source;
private String cust_industry;
private String cust_level;
private String cust_linkman;
private String cust_phone;
private String cust_mobile;
private Set<Linkman> linkmans = new HashSet<Linkman>();
}
* 聯絡人的JavaBean如下
public class Linkman {
private Long lkm_id;
private String lkm_name;
private String lkm_gender;
private String lkm_phone;
private String lkm_mobile;
private String lkm_email;
private String lkm_qq;
private String lkm_position;
private String lkm_memo;
private Customer customer;
}
4. 編寫客戶和聯絡人的對映配置檔案(注意一對多的配置編寫)
* 客戶的對映配置檔案如下
<class name="com.itheima.domain.Customer" table="cst_customer">
<id name="cust_id" column="cust_id">
<generator class="native"/>
</id>
<property name="cust_name" column="cust_name"/>
<property name="cust_user_id" column="cust_user_id"/>
<property name="cust_create_id" column="cust_create_id"/>
<property name="cust_source" column="cust_source"/>
<property name="cust_industry" column="cust_industry"/>
<property name="cust_level" column="cust_level"/>
<property name="cust_linkman" column="cust_linkman"/>
<property name="cust_phone" column="cust_phone"/>
<property name="cust_mobile" column="cust_mobile"/>
<set name="linkmans">
<key column="lkm_cust_id"/>
<one-to-many class="com.itheima.domain.Linkman"/>
</set>
</class>
* 聯絡人的對映配置檔案如下
<class name="com.itheima.domain.Linkman" table="cst_linkman">
<id name="lkm_id" column="lkm_id">
<generator class="native"/>
</id>
<property name="lkm_name" column="lkm_name"/>
<property name="lkm_gender" column="lkm_gender"/>
<property name="lkm_phone" column="lkm_phone"/>
<property name="lkm_mobile" column="lkm_mobile"/>
<property name="lkm_email" column="lkm_email"/>
<property name="lkm_qq" column="lkm_qq"/>
<property name="lkm_position" column="lkm_position"/>
<property name="lkm_memo" column="lkm_memo"/>
<many-to-one name="customer" class="com.itheima.domain.Customer" column="lkm_cust_id"/>
</class>
Hibernate的關聯關係對映之多對多對映
技術分析之多對多的建表原則
1. JavaWEB的多對多
技術分析之多對多JavaBean的編寫
1. 編寫使用者和角色的JavaBean
* 使用者的JavaBean程式碼如下
public class User {
private Long user_id;
private String user_code;
private String user_name;
private String user_password;
private String user_state;
private Set<Role> roles = new HashSet<Role>();
}
* 角色的JavaBean程式碼如下
public class Role {
private Long role_id;
private String role_name;
private String role_memo;
private Set<User> users = new HashSet<User>();
}
2. 使用者和角色的對映配置檔案如下
* 使用者的對映配置檔案如下
<class name="com.itheima.domain.User" table="sys_user">
<id name="user_id" column="user_id">
<generator class="native"/>
</id>
<property name="user_code" column="user_code"/>
<property name="user_name" column="user_name"/>
<property name="user_password" column="user_password"/>
<property name="user_state" column="user_state"/>
<set name="roles" table="sys_user_role">
<key column="user_id"/>
<many-to-many class="com.itheima.domain.Role" column="role_id"/>
</set>
</class>
* 角色的對映配置檔案如下
<class name="com.itheima.domain.Role" table="sys_role">
<id name="role_id" column="role_id">
<generator class="native"/>
</id>
<property name="role_name" column="role_name"/>
<property name="role_memo" column="role_memo"/>
<set name="users" table="sys_user_role">
<key column="role_id"/>
<many-to-many class="com.itheima.domain.User" column="user_id"/>
</set>
</class>
3. 多對多進行雙向關聯的時候:必須有一方去放棄外來鍵維護權
相關文章
- mybatis關聯關係對映MyBatis
- Hibernate (開源物件關係對映框架)物件框架
- JPA關係對映系列四:many-to-many 關聯對映
- JPA關係對映系列五:many-to-many 關聯表存在額外欄位關係對映
- python 關係對映Python
- Hibernate中實體類對映檔案表與表的關係模版
- java物件關係對映ROMJava物件
- hibernate中多對多關係的維護
- 6.Hibernate多對多關係建立
- Mybatis實體關聯對映MyBatis
- CRM和ERP的Sales Organization的對映關係
- MyBatis加強(1)~myBatis物件關係對映(多對一關係、一對多關係)、延遲/懶載入MyBatis物件
- Spring Boot 入門系列(二十八) JPA 的實體對映關係,一對一,一對多,多對多關係對映!Spring Boot
- 表的關聯關係
- day07-MyBatis的關聯對映01MyBatis
- MyBatis實現一對一關聯對映MyBatis
- ERP的Account group和CRM partner group的對映關係
- Verilog程式碼和FPGA硬體的對映關係(五)FPGA
- Verilog程式碼和FPGA硬體的對映關係(四)FPGA
- python 類關聯關係Python
- TiDB從關係模型對映到key-value(圖)TiDB模型
- 7.Hibernate一對多關係建立與錯誤解決
- 【新包】根據 appends 配置的關聯欄位對映關係,自動維護需要的 appends - Laravel Eloquent Append AutomationAPPLaravel
- Spring Data JPA 之 一對一,一對多,多對多 關係對映Spring
- JPA(3) 表關聯關係(多對一、一對多、多對多、一對一)
- C# 資料操作系列 - 6 EF Core 配置對映關係C#
- Fluent API 配置實體和資料庫之間的對映關係API資料庫
- 淺談Mybatis中是如何實現這種多表關係的對映MyBatis
- JavaEE MyBatis關聯對映之多對多(教材學習筆記)JavaMyBatis筆記
- Hibernate【對映】知識要點
- 8 張圖掌握 Laravel 的 Eloquent 關聯關係Laravel
- 體系結構、指令定址、對映關係、系統可靠性
- 物件導向程式設計程式碼詳解(依賴關係,關聯關係,組合關係)物件程式設計
- 物聯網與APP的關係?APP
- Hibernate--單表對映總結
- 在 CSDN 上面看到的一篇關於 Laravel 關聯表模型和多對多關係的文章Laravel模型
- 3分鐘短文:說說Laravel模型關聯關係最單純的“一對一”Laravel模型
- Laravel 之多對多的關係模型Laravel模型