Hibernate 的關聯關係對映

Kunaly發表於2018-03-06

需求分析

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. 多對多進行雙向關聯的時候:必須有一方去放棄外來鍵維護權


相關文章