• Hibernate中的一对一映射关系


    Hibernate中的一对一映射关系有两种实现方法(单向一对一,和双向一对一)(一对一关系:例如一个department只能有一个manager)

    单向和双向有什么区别呢??
    例如若是单向一对一,比如在department中插入一个外键关联manager表(manager_id),那此时插入数据时,就必须先插入manager表的数据再插入department表的数据,而且使用Hibernate检索数据时,查询department的数据,如果没有使用懒加载,则manager的对应的数据也会被查询处出来,
    但是如果是双向一对一,可以任意插入一方的数据,查询数据时,无论查询哪一方,被关联方也会被检索处理

      I单向一对一

      配置步骤:

      ①:分析1端和n端(如果是一对一关系的时候,可以选择任意一方为N端,)

      ②:在1端插入n端的集合属性(因为是一对一,所以不可以使集合对象属性,只能使用对象属性)

      ③:在n端插入一端的对象属性

      ④:注明关系在那一段维护

      步骤:1在一对一关联的持久化类中互相添加对方对象属性,
           例如在department中添加private manager manager属性:

           department代码如下:

    package com.atguigu.hibernate.one2one.foreign;
    
    public class Department {
    
        private Integer deptId;
        private String deptName;
        
        private Manager mgr;
    
        public Integer getDeptId() {
            return deptId;
        }
    
        public void setDeptId(Integer deptId) {
            this.deptId = deptId;
        }
    
        public String getDeptName() {
            return deptName;
        }
    
        public void setDeptName(String deptName) {
            this.deptName = deptName;
        }
    
        public Manager getMgr() {
            return mgr;
        }
    
        public void setMgr(Manager mgr) {
            this.mgr = mgr;
        }
        
        
        
    }

        manager的代码:

        

    package com.atguigu.hibernate.one2one.foreign;
    
    public class Manager {
    
        private Integer mgrId;
        private String mgrName;
        
        private Department dept;
    
        public Integer getMgrId() {
            return mgrId;
        }
    
        public void setMgrId(Integer mgrId) {
            this.mgrId = mgrId;
        }
    
        public String getMgrName() {
            return mgrName;
        }
    
        public void setMgrName(String mgrName) {
            this.mgrName = mgrName;
        }
    
        public Department getDept() {
            return dept;
        }
    
        public void setDept(Department dept) {
            this.dept = dept;
        }
        
        
        
    }

        2对于基于外键的1-1关联,其外键可以存放在任意一边,在需要存放外键一端,增加many-to-one元素。为many-to-one元素且增加unique=“true” 属性来表示为1-1关联

        

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    <hibernate-mapping>
    
        <class name="com.atguigu.hibernate.one2one.foreign.Department" table="DEPARTMENTS">
    
            <id name="deptId" type="java.lang.Integer">
                <column name="DEPT_ID" />
                <generator class="native" />
            </id>
            
            <property name="deptName" type="java.lang.String">
                <column name="DEPT_NAME" />
            </property>
            
            <!-- 使用 many-to-one 的方式来映射 1-1 关联关系,其实many-to-one 就是可以用来生成外键 -->
         <many-to-one name="mgr" class="com.atguigu.hibernate.one2one.foreign.Manager" column="MGR_ID" unique="true">
        </many-to-one>                     
        </class>
    </hibernate-mapping>

      另一端需要使用one-to-one元素,该元素使用 property-ref 属性指定使用被关联实体主键以外的字段作为关联字段(就是要指定外键是哪一个,记得是使用Java的属性名,不是使用Sql的列名)

      

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    
    <hibernate-mapping>
    
        <class name="com.atguigu.hibernate.one2one.foreign.Manager" table="MANAGERS">
            
            <id name="mgrId" type="java.lang.Integer">
                <column name="MGR_ID" />
                <generator class="native" />
            </id>
            
            <property name="mgrName" type="java.lang.String">
                <column name="MGR_NAME" />
            </property>
            
            <!-- 映射 1-1 的关联关系: 在对应的数据表中已经有外键了, 当前持久化类使用 one-to-one 进行映射 -->
            <!-- 
                没有外键的一端需要使用one-to-one元素,该元素使用 property-ref 属性指定使用被关联实体主键以外的字段作为关联字段
             -->
            <one-to-one name="dept" class="com.atguigu.hibernate.one2one.foreign.Department" 
          property-ref="mgr"></one-to-one> </class> </hibernate-mapping>

    对于一对一关联映射,记得千万不要两张表都设置外键,这样会引起逻辑错误的

    II双向一对一映射关系
      步骤:1在一对一关联的持久化类中互相添加对方对象属性,
           例如在department中添加private manager manager属性:这个代码跟I那里没区别,都一样

          2在需要生成外键的那个表对应的持久化类的.hbm.xml文件中指定主键的映射策略为foreign策略,
         表明根据”对方”的主键来生成自己的主键,自己并不能独立生成主键. <param> 子元素指定使用
         当前持久化类的哪个属性作为 “对方” 采用foreign主键生成器策略的一端增加 one-to-one 元素
           映射关联属性,其one-to-one属性还应增加 constrained=“true” 属性

         代码如下:

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    <hibernate-mapping package="com.atguigu.hibernate.one2one.primary">
        <class name="Department" table="DEPARTMENTS">
    
            <id name="deptId" type="java.lang.Integer">
                <column name="DEPT_ID" />
                <!-- 使用外键的方式来生成当前的主键 -->
                <generator class="foreign">
                    <!-- property 属性指定使用当前持久化类的哪一个属性的主键作为外键 -->
                    <param name="property">mgr</param>
                </generator>
            </id>
            
            <property name="deptName" type="java.lang.String">
                <column name="DEPT_NAME" />
            </property>
            
            <!--  
            采用 foreign 主键生成器策略的一端增加 one-to-one 元素映射关联属性,
            其 one-to-one 节点还应增加 constrained=true 属性, 以使当前的主键上添加外键约束
            -->
            <one-to-one name="mgr" class="Manager" constrained="true"></one-to-one>
                                
        </class>
    </hibernate-mapping>

    另一端增加one-to-one元素映射关联属性。

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    
    <hibernate-mapping>
    
        <class name="com.atguigu.hibernate.one2one.primary.Manager" table="MANAGERS">
            
            <id name="mgrId" type="java.lang.Integer">
                <column name="MGR_ID" />
                <generator class="native" />
            </id>
            
            <property name="mgrName" type="java.lang.String">
                <column name="MGR_NAME" />
            </property>
            
            <one-to-one name="dept" class="com.atguigu.hibernate.one2one.primary.Department">
         </
    one-to-one> </class> </hibernate-mapping>

    以上就是一对一映射关系的配置,不过有没有想到,当从不同的表来访问关联表的数据,访问过程是怎样的???()

  • 相关阅读:
    windows环境配置多个tomcat
    navicat 12 破解
    Eclipse创建Maven报异常:Could not get the value for parameter encoding for plugin......
    tomcat设置日志打印到文件中
    修改mysql数据库的休眠时间
    spring的bean标签的常用属性
    redis 安装与下载(windows版本)
    mysql设置远程可访问
    WPF非轮询方式更新数据库变化SqlDependency(数据库修改前台自动更新)
    WPF实战案例-在线程内同步集合数据到UI线程
  • 原文地址:https://www.cnblogs.com/jeremy-blog/p/4012057.html
Copyright © 2020-2023  润新知