zoukankan      html  css  js  c++  java
  • Hibernate 系列教程7-双向一对一

    双向一对一
    一对一主要用在
    一个一方需要的信息比较少,比如注册的登录信息
    另一个一方存储的信息比较多,比如注册之后用户填写的详细信息

    实现方式常用的主要有2种:
    java模型都是一样,其中一个映射文件有所不同
    hibernate.cfg.xml

    <mapping resource="com/jege/hibernate/two/way/onetoone/User.hbm.xml" />
    <mapping resource="com/jege/hibernate/two/way/onetoone/UserInfo.hbm.xml" />

    User

    //主一
    public class User {
      private Long id;
      private String username;
      private String password;
      private UserInfo info;

    UserInfo

    //从一
    public class UserInfo {
      private Long id;
      private Integer age;
      private String address;
      private User user;

    User.hbm.xml

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
            "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
    
    <hibernate-mapping package="com.jege.hibernate.two.way.onetoone">
        <class name="User" table="t_user">
            <id name="id">
                <generator class="native" />
            </id>
            <property name="username" />
            <property name="password" />
            <one-to-one name="info" class="UserInfo" />
        </class>
    </hibernate-mapping>       

    模拟外键一对一UserInfo.hbm.xml

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
            "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
    
    <hibernate-mapping package="com.jege.hibernate.two.way.onetoone">
        <class name="UserInfo" table="t_user_info">
            <id name="id">
                <generator class="native" />
            </id>
            <property name="age" />
            <property name="address" />
            <!-- 使用多对一的方式来模拟一对一的关系 -->
            <!-- unique="true"外键的唯一 -->
            <many-to-one name="user" class="User" column="user_id" unique="true" />
        </class>
    </hibernate-mapping> 
    
    CREATE TABLE `t_user_info` (
      `id` bigint(20) NOT NULL AUTO_INCREMENT,
      `age` int(11) DEFAULT NULL,
      `address` varchar(255) DEFAULT NULL,
      `user_id` bigint(20) DEFAULT NULL,
      PRIMARY KEY (`id`),
      UNIQUE KEY `UK_ln50dwtk2w5skl1rpjfek5srv` (`user_id`),
      CONSTRAINT `FK_ln50dwtk2w5skl1rpjfek5srv` FOREIGN KEY (`user_id`) REFERENCES `t_user` (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;       

    共享主键一对一

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
            "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
    
    <hibernate-mapping package="com.jege.hibernate.two.way.onetoone">
        <class name="UserInfo" table="t_user_info">
            <id name="id">
                <generator class="foreign">
                    <!-- UserInfo的主键来自于当前user属性的id -->
                    <param name="property">user</param>
                </generator>
            </id>
            <property name="age" />
            <property name="address" />
            <!-- 共享主键是关系双方的主键是一样的值 -->
            <!-- constrained="true"添加约束的关键 -->
            <one-to-one name="user" constrained="true" />
        </class>
    </hibernate-mapping> 
    
    CREATE TABLE `t_user_info` (
      `id` bigint(20) NOT NULL,
      `age` int(11) DEFAULT NULL,
      `address` varchar(255) DEFAULT NULL,
      PRIMARY KEY (`id`),
      CONSTRAINT `FK_ihje4vsyvt8vmuhru59ib9j1d` FOREIGN KEY (`id`) REFERENCES `t_user` (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    

    还有一种可以使用多一张中间表,设置主键唯一,外键同时唯一的方式,不过基本没有使用场景。

    源码地址

    https://github.com/je-ge/hibernate

    如果觉得我的文章对您有帮助,请予以打赏。您的支持将鼓励我继续创作!谢谢!
    微信打赏
    支付宝打赏

  • 相关阅读:
    AJAX 三级联动
    AJAX JSON类型返回
    AJAX 汽车详细信息练习
    JQ AJAX
    对话框关联两个Layout时
    删除,拨打电话,发送短信对话框
    自定义对话框,时间日期对话框
    一般对话框,单选复选对话框
    JAVA。String转Int
    加监听器,单选复选按钮
  • 原文地址:https://www.cnblogs.com/je-ge/p/6105428.html
Copyright © 2011-2022 走看看