关闭

hibernate 关联映射 双向多对一(一对多)

标签: hibernate
314人阅读 评论(0) 收藏 举报
分类:

1,实体类
(1)Address(多端)(get,set方法省略)

private int addressid;
    private String addressinfo;
    private User user;//引用关联实体
(2)User(一端)(get,set方法省略)
    private  int userid;
    private String name;
    private String password;
    private Set<Address> address;//引用集合属性

2,配置文件
Address.hbm.xml文件中

    <hibernate-mapping>
    <class name="com.john.hibernate.entity.Address" table="t_address_tab">
        <!-- 映射标识属性address_id  identity主键生成器 -->
        <id name="addressid" type="int">
            <column name="address_id" />
            <generator class="identity" />
        </id>
        <property name="addressinfo" type="java.lang.String">
            <column name="address_info" />
        </property>
        <many-to-one name="user" class="com.john.hibernate.entity.User" fetch="join">
            <column name="user_id" /><!-- column 属性指定外键列名 -->
        </many-to-one>
    </class>
</hibernate-mapping>

在User配置文件中:

<hibernate-mapping>
    <class name="com.john.hibernate.entity.User" table="t_user_tab">
         <!-- 映射标识属性user_id  identity主键生成器 -->
        <id name="userid" type="int">
            <column name="user_id" />
            <generator class="identity" />
        </id>
        <property name="name" type="java.lang.String">
            <column name="name" />
        </property>
        <!-- 映射集合属性,关联到持久化类,inverse="true" 控制关联关系 -->
        <set name="address" table="address" inverse="true" lazy="true">
            <key>
                <column name="user_id" /><!-- 指定关联的外键列名 -->
            </key>
            <one-to-many class="com.john.hibernate.entity.Address" /><!-- 映射关系类 -->
        </set>
    </class>
</hibernate-mapping>

0
0
查看评论

【Hibernate步步为营】--(一对多映射)之双向关联

单向关联的一对多映射,在一的一端维护双向的关系这种做法虽然能实现但是存在很多缺陷,首先生成很多多余的SQL语句,因为多的一端不维护关系,只有一的一端维护,在进行操作时一的一端会发出多余的update语句;其次,因为多的一端不知道一的一端存在,所以在保存多的一端时如果外键为null值,并且在设计数据库...
  • zhang_xinxiu
  • zhang_xinxiu
  • 2014-05-25 14:26
  • 4332

hibernate5(11)注解映射[3]一对多多对一双向关联

在上两篇文章里,我们详细地分别讲解了一对多和多对一的单向关联配置的具体属性含义,在这一篇文章里,我们完成两者的的整合建立双向关联。 在实际的博客网站中,我们可能需要根据文章读取作者(用户)信息,但肯定也要让用户能获取自己的文章信息,针对这种需求,我们可以建立文章(多)对用户(一)的双向关联映射。 ...
  • qwe6112071
  • qwe6112071
  • 2016-04-08 08:51
  • 3812

hibernate(四)一对多单向、多对一双向、自身双向关联

​经过前几篇文章的简略总结,主要认识了关于hibernate的基本认识,顺便认识了hibernate的简单的一个原理。具体参见 Hibernate (一)hibernate入门   Hibernate(二)hibernate原理简单实现对比JDBC hiber...
  • chenfanglincfl
  • chenfanglincfl
  • 2015-04-28 01:10
  • 2794

hibernate一对多双向注解

多的一方@Entity @Table(name = "TEMPLET") public class Templet { @Id @SequenceGenerator(name="TEMPLET_SEQ",sequenceName="TEMPLET...
  • XueSeYaoTong
  • XueSeYaoTong
  • 2015-11-26 16:28
  • 1005

Hibernate关联映射之一对多,多对一以及双向一对多

在上篇博客我们讲了hibernate对单表的操作,本篇博客就来讲讲对多表的关联映射操作。首先我们拿来做例子的表为班级表1---n学生表,在这次的测试主键我用的是序列,创建代码如下: --班级表 drop table classes; create table classes( cid ...
  • qq_26624661
  • qq_26624661
  • 2016-08-13 15:17
  • 2231

【SSH进阶之路】Hibernate映射——多对一单向关联映射(四)

基本映射是对一个实体进行映射,关联映射就是处理多个实体之间的关系,将关联关系映射到数据库中,所谓的关联关系在对象模型中有一个或多个引用。
  • jiuqiyuliang
  • jiuqiyuliang
  • 2014-10-22 08:15
  • 31416

Hibernate关联映射——一对多(多对一)

Hibernate关联映射——一对多(多对一)我们以客户(Customer)与订单(Order)为例来讲解Hibernate关联映射中的一对多关联关系。 首先肯定是搭建好Hibernate的开发环境,我在此也不过多赘述,读者自行实践。接着在src目录下创建一个cn.itheima.oneToMan...
  • yerenyuan_pku
  • yerenyuan_pku
  • 2017-04-13 02:36
  • 1284

Hibernate一对多双向注解配置实例

*customer和order是一对多的关系,一个用户可以有多条订单,一条订单只能从属于一个用户。 所以,customer是一的一方,order是多的一方。*package com.lejuad.lejuadhome.manager.entity;import java.io.Serializab...
  • gongzhufanlulu
  • gongzhufanlulu
  • 2016-04-29 10:17
  • 2165

Hibernate xml一对多关联映射 单向+双向

1.单向 一对多关联映射利用了多对一关联映射原理。 多对一关联映射:在多的一端加入一个外键指向一的一端,它维护的关系是多指向一; 一对多关联映射:在多的一端加入一个外键指向一的一端,它维护的关系是一指向多。 即两者的映射策略是相同的,只是看待问题的角度不同。 举例:Cl
  • yyywyr
  • yyywyr
  • 2011-08-09 11:07
  • 2761

hibernate一对多关联映射——双向(非常常用)

原文地址:http://blog.sina.com.cn/s/blog_5fad23090100fct8.html 一对多关联映射通常设为双向的,关系字段设置在一的一端,而且在多的一端维护, 一、解析: 1、  一对多双向关联也就是说,在加载班级时,能够知道这个班级所有的学生。 同...
  • springsen
  • springsen
  • 2012-08-08 16:32
  • 3542
    个人资料
    • 访问:18201次
    • 积分:430
    • 等级:
    • 排名:千里之外
    • 原创:25篇
    • 转载:5篇
    • 译文:0篇
    • 评论:4条
    最新评论