`

Hibernate关联映射-one to many外键单向关联

 
阅读更多

以下是说明,1对多 单向外键关联 的实例.同样以person 和 address 为例.

 

 

为了方便测试,在原有的Hibernate框架上面,建立两个hbm.xml文件..

一个是Address_One_to_Many.hbm.xml,另外一个是Person_One_to_Many.hbm.xml。

然后,建立两个JavaBean 分别是:Address_One_to_Many 和 Person_One_to_Many

 

 

Person_One_to_Many具体内容如下:

/**
 * 1对多,单向关联
 * @author Administrator
 *
 */
public class Person_One_to_Many implements Serializable{
	
	private static final long serialVersionUID = -6313867775683964530L;
	private Integer id;
	private String name;
	private Integer age;
	
	//一个人,有多个地址;
	private Set<Address_One_to_Many> setAddress = new HashSet<Address_One_to_Many>();
      
                //getter 和 setter 方法省略	
}

 

 

Address_One_to_Many 具体代码如下:

/**
 * 
 * 一对多的关系;
 * @author Administrator
 *
 */
public class Address_One_to_Many implements Serializable{
	
	private static final long serialVersionUID = 3635140598485086087L;
	private Integer addressID;
	private String addressDetail;
               
                //getter 和 setter方法省略.
}

 

 

接下来就是配置Mapping映射文档.

Person_One_to_Many.hbm.xml 具体代码如下:

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="pack.java.model">
	<class name="Person_One_to_Many" table="ZHT_Person_One_To_Many">
		<id name="id" column="ID" type="java.lang.Integer">
			<!-- mySql中主键id自动生成. -->
			<generator class="identity">
			</generator>
		</id>
		
		<!-- PERSON_ONE_TO_MANY属性的定义 -->
		<property name="name" column="NAME" type="java.lang.String"></property>
		<property name="age" column="AGE" type="java.lang.Integer"></property>
		
		<!-- 
			设置Address地址set集合,inverse = false代表主控制端; lazy=false代表不延迟加载.
			table=ADDRESS_ONE_TO_MANY 指定数据库的ADDRESSS一张表;方便关联查询;
			cascade=all 支持所有的级联操作;
		-->
		<set name="setAddress" inverse="false" lazy="false" table="ADDRESS_ONE_TO_MANY" cascade="all">
			<!-- 确定关联的外键列,可以任意取个名字;-->
			<key column="id" not-null="false"></key>
			<!-- 1个人多对应多个地址,所以class指向的是Address -->
			<one-to-many class="Address_One_to_Many"/>
		</set>
	</class>
</hibernate-mapping>

 

 

Address_One_to_Many.hbm.xml:

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
                                   "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="pack.java.model">
 <class name="Address_One_to_Many" table="ADDRESS_ONE_TO_MANY">
  <id column="ADDRESS_ID" name="addressID" type="java.lang.Integer">
   <generator class="identity"/>
  </id>
  
  <!-- ADDRESS_ONE_TO_MANY属性的定义; -->
  <property  lazy="false" name="addressDetail" column="ADDRESS_DETAIL" not-null="true"/>
 </class>
</hibernate-mapping>

 

 

配置完之后,记得在Hibernate.cfg.xml中加上 刚才新建xxx.hbm.xml文件的映射地址:

比如:

<mapping resource="pack/java/model/Address_One_to_Many.hbm.xml"/>
<mapping resource="pack/java/model/Person_One_to_Many.hbm.xml"/>

 

 

最后,在建立一个Test类进行测试刚刚配置的1对多的映射关系.

package pack.java.test;
import java.io.Serializable;
import java.util.Set;
import org.hibernate.Session;
import pack.java.hibernate.HibernateSessionFactory;
import pack.java.model.Address_One_to_Many;
import pack.java.model.Person_One_to_Many;
/**
 * 
 * Hibernate 测试类; 一对多外键单向关联;
 * @author ZhouHaiTao
 *
 */
public class HibernateDemoOneToMany {
	public static void main(String[] args) {
		HibernateDemoOneToMany hibernateDemoOneToMany = new HibernateDemoOneToMany();
		//保存地址;
		hibernateDemoOneToMany.saveAddress();
		
		//保存人物;
		hibernateDemoOneToMany.savePerson();
		
		//根据Person id查询person;
		hibernateDemoOneToMany.loadPersonByID(1);
	}
	
	/**
	 * 保存Address地址;
	 */
	private void saveAddress(){
		Session session = getSession();
		Address_One_to_Many address1 = new Address_One_to_Many();
		address1.setAddressDetail("湖南省株洲市");
	
		Address_One_to_Many address2 = new Address_One_to_Many();
		address2.setAddressDetail("广东省深圳市");
		
		Address_One_to_Many address3 = new Address_One_to_Many();
		address3.setAddressDetail("湖北省武汉市");
		
		//开始事务;
		session.beginTransaction().begin();
		//单独保存地址;
		session.save(address1);
		session.save(address2);
		session.save(address3);
		//提交事务;
		session.beginTransaction().commit();
		
		//关闭session;
		closeSession(session);
	}
	
	/**
	 * 保存Person,并且给Person指定多个地址;
	 */
	private void savePerson(){
		//获取session;
		Session session = getSession();
		Person_One_to_Many person1 = new Person_One_to_Many("李四",23);
		Person_One_to_Many person2 = new Person_One_to_Many("张三",23);
		
		Address_One_to_Many address1 = new Address_One_to_Many();
		address1.setAddressDetail("湖南省株洲市");
	
		Address_One_to_Many address2 = new Address_One_to_Many();
		address2.setAddressDetail("广东省深圳市");
		
		Address_One_to_Many address3 = new Address_One_to_Many();
		address3.setAddressDetail("湖北省武汉市");
		
		session.beginTransaction().begin();
		
		//给添加person1对象添加两个地址;
		person1.getSetAddress().add(address1);
		person1.getSetAddress().add(address2);
		
		//给person2对象,添加一个地址;
		person2.getSetAddress().add(address3);
		session.save(person1);
		session.save(person2);
		session.beginTransaction().commit();
		
		//关闭session;
		closeSession(session);
	}
	
	
	/**
	 * 根据person id查询出,person对象,以及地址;
	 * @param id
	 */
	private void loadPersonByID(Serializable id){
		Session session = getSession();
		Person_One_to_Many personOneToMany = (Person_One_to_Many) session.load(Person_One_to_Many.class, id);
		System.out.println("打印出Person中的属性信息:");
		System.out.println(personOneToMany.getId()+","+personOneToMany.getName()+","+personOneToMany.getAge());
		Set<Address_One_to_Many> addressOneToManies = personOneToMany.getSetAddress();
		
		System.out.println("\n打印出Address中的信息:");
		for(Address_One_to_Many  addressOneToMany : addressOneToManies){
			System.out.println(addressOneToMany.getAddressID()+","+addressOneToMany.getAddressDetail());
		}
		closeSession(session);
	}
	
	/**
	 * 创建session;
	 * @return
	 */
	private static Session getSession(){
		return HibernateSessionFactory.getSession();
	}
	
	/**
	 * 创建session;
	 * @return
	 */
	private static void closeSession(Session session){
		session.close();
	}
}

 

 

测试之后,可以在MySql中查看数据数据是否正常插入成功..

 

以下是控制台输出的信息,代表成功插入数据库:

 

打印出Person中的属性信息:
1,周海涛,23

打印出Address中的信息:
5,湖南省株洲市
4,广东省深圳市

 

分享到:
评论

相关推荐

    hibernate one-to-one 一对一唯一外键关联映射_单向 and 双向

    在Hibernate中,一对一唯一外键关联映射可以通过 `&lt;many-to-one&gt;` 标签来配置。例如,以下是Person实体与IdCard实体的一对一唯一外键关联映射配置: ```xml &lt;many-to-one name="idCard" column="card_id...

    hibernate的关联映射

    关联映射主要包括四种类型:一对一(One-to-One)、一对多(One-to-Many)、多对一(Many-to-One)和多对多(Many-to-Many)。下面我们将逐一探讨这些关联映射的配置方法。 1. **一对一关联映射** - **主键关联**...

    hibernate 全面学习->hibernate 关联映射学习

    接下来是“多对一”(Many-to-One)映射,与一对多相反,一个子实体可以关联到多个父实体。例如,多个订单可以属于同一个客户。`hibernate_many2one`的案例可能展示了如何在子类中使用`@ManyToOne`注解来指定与父类...

    Hibernate关联映射

    在 Hibernate 映射中,需要使用 `one-to-one` 元素,并设置 `constrained="true"`,表明该类的主键由关联类生成。 3. Hibernate 一对一连接表单向关联: 这种关联方式是通过额外的连接表来实现一对一关系的。连接...

    hibernate one-to-many 单/双向关联映射配置心得

    本文主要关注Hibernate中的一个核心概念——一对一(One-to-One)、一对多(One-to-Many)和多对一(Many-to-One)关联映射,特别是关于“一到多”单向和双向关联映射的配置心得。 首先,让我们了解“一到多”关联...

    hibernate实体关联关系映射

    2. **一对多关联**(One-to-Many / Many-to-One) - 外键单向关联 - 连接表单向关联 - 外键双向关联 - 连接表双向关联 3. **多对多关联**(Many-to-Many) - 单向关联 - 双向关联 每种关联类型都有其特定的...

    Hibernate 一对多外键单向关联

    这里的`many-to-one`元素表示Address与Person的一对多关联,column属性指定了外键列的名称,class属性指定了Person实体的全限定类名,cascade属性可以指定级联操作。 在实际使用中,可以通过Hibernate的Session接口...

    Hibernate关联关系映射目录

    -- 用来映射关联PO,必须为one-to-one元素增加constrained="true"属性 --&gt; &lt;one-to-one name="address" constrained="true"/&gt; &lt;/hibernate-mapping&gt; ``` --- ##### 3. 一对一连接表单向关联 在一对一连接表单...

    hibernate-one-to-many-uni

    【标题】"hibernate-one-to-many-uni" 指的是在Hibernate框架下实现的一对多单向关联关系。Hibernate是Java开发中常用的持久化框架,它简化了数据库操作,使得开发者可以更加专注于业务逻辑而不是数据库交互。在这个...

    hibernate关联映射

    在Person类中添加`private Address address`属性,并在`person.hbm.xml`中配置`&lt;many-to-one&gt;`元素,如`&lt;many-to-one name="address" cascade="all" class="Address" column="address_id"/&gt;`。这表示Person表中的...

    Hibernate关联映射.doc

    - 多方配置文件中添加`&lt;many-to-one&gt;`标签,表示多方与一方之间的关联。 ```xml &lt;many-to-one name="一方对象作为属性的名称" class="一方类包括了路径的" column="一方主键id" not-null="true"/&gt; ``` 3. **...

    Hibernate一对多单向关联映射

    `&lt;key&gt;`元素定义了外键列名,`&lt;one-to-many&gt;`元素指定被关联的实体类。 三、实体类定义 在Department实体类中,需要有一个类型为Set的属性,对应映射文件中的`&lt;set&gt;`元素。 ```java public class Department { //...

    myeclipse试用小记----Hibernate多对一单向关联(1)

    3. **映射文件**:如果使用传统的Hibernate XML映射文件,需要在`.hbm.xml`文件中配置多对一关联,设置`&lt;many-to-one&gt;`标签。如果是注解方式,直接在Java类中使用上述提到的注解。 4. **数据访问对象(DAO)**:...

    Hibernate中的关联映射

    &lt;many-to-one name="address" class="Address" column="address_id"/&gt; ``` - **基于PK**:同样只有一方包含了另一方的引用关联实体属性,但这里通过使用外键作为主键的一部分来实现。 - **映射示例**: ```xml ...

    hibernate的关联关系映射

    3. **第三种方式**:这是对唯一外键关联的一种变体,两个实体都包含对方的外键字段,但在配置文件中使用`&lt;many-to-one&gt;`标签,模拟一对一关联。 **二、一对多、多对一关联** 在选课系统中,一个教师可以教多个课程...

    Hibernate教程10_关系映射之多对一单向关联

    这里的`many-to-one`元素定义了多对一的关系。`name`属性指定了在员工类中对应的属性名(这里是`department`),`class`属性是部门实体的全限定类名,`column`属性是数据库表中对应的外键列名(假设为`dept_id`)。 ...

    Hibernate映射文件[文].pdf

    - 在多方的映射文件中,通过 `&lt;many-to-one&gt;` 标签定义一个引用,指定关联的列和被引用的实体类。例如,学生(Student)可以引用班级(Classes)。 3. **一对一关系**: - **外键关联**: - **单向**:在维护...

    hibernate关系映射

    在Hibernate映射文件中,通过`&lt;many-to-one&gt;`标签将User类的group属性映射到t_user表的gid外键。 - 反之,如果一个User属于一个Group(一对多),则在Group类中添加一个User的集合。映射文件中,使用`&lt;set&gt;`标签...

Global site tag (gtag.js) - Google Analytics