双向一对多关系:两个实体中都包含另一个实体的对象。

关键代码:

// 1.加上属性
private Set<Orders> orders = new HashSet<>();
// 2.加上get 、set方法,代码略
    <!-- 
    一对多的集合属性
    table:多的表名
    inverse="true" 反转,听order的。例如全国人品都听主席的。
    -->
    <set name="orders" table="ORDERS" inverse="true">
        <!-- 多的列的外键名字 -->
        <key column="USER_ID"></key>
	<!-- 指定映射关系 -->
        <one-to-many class="com.shuoeasy.test.Orders"/>
    </set>


详细代码:

User.java:

package com.shuoeasy.test;

import java.util.HashSet;
import java.util.Set;

public class User {
	private int id;
	private String userName;
	
	// 初始化可以防止空指针异常
	private Set<Orders> orders = new HashSet<>();
	
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getUserName() {
		return userName;
	}
	public void setUserName(String userName) {
		this.userName = userName;
	}
	
	public Set<Orders> getOrders() {
		return orders;
	}
	public void setOrders(Set<Orders> orders) {
		this.orders = orders;
	}
	
	@Override
	public String toString() {
		// 最好不要输出orders,否则可能会出现内存溢出java.lang.StackOverflowError
		//return "User [id=" + id + ", userName=" + userName + ", orders=" + orders + "]";
		return "User [id=" + id + ", userName=" + userName + "]";
	}

	
}

User.hbm.xml:

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2016-6-25 14:50:51 by Hibernate Tools 3.4.0.CR1 -->
<hibernate-mapping>
	<class name="com.shuoeasy.test.User" table="USER">
		<id name="id" type="int">
			<column name="ID" />
			<!-- 指定主键的生成方式,native:使用数据库本地方式 -->
			<generator class="native" />
		</id>
		<property name="userName" type="java.lang.String">
			<column name="USERNAME" />
		</property>
		
		<!-- 
		一对多的集合属性
		table:多的表名
		inverse="true" 反转,听order的。例如全国人品都听主席的。
		 -->
		 <set name="orders" table="ORDERS" inverse="true">
		 	<!-- 多的列的外键名字 -->
			<key column="USER_ID"></key>
			<!-- 指定映射关系 -->
			<one-to-many class="com.shuoeasy.test.Orders"/>
		</set> 

	</class>
</hibernate-mapping>

Order.java以及Order.hbm.xml代码略


AppTest.java:

package com.shuoeasy.test;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;


/**
 * Unit test for simple App.
 */
public class AppTest {
	Session session;
	SessionFactory sf;

	@Before
	public void init() {

		Configuration conf = new Configuration().configure();

		ServiceRegistry sr = new StandardServiceRegistryBuilder().applySettings(conf.getProperties()).build();

		sf = conf.buildSessionFactory((org.hibernate.service.ServiceRegistry) sr);

		session = sf.openSession();

		session.beginTransaction();
		System.out.println("init");
	}

	@After
	public void destory() {
		session.getTransaction().commit();

		session.close();

		sf.close();
		System.out.println("dectory");
	}

	/**
	 * 插入数据
	 */
	@Test
	public void testInsert(){
		User user = new User();
		user.setUserName("张三");
		
		Orders order1 = new Orders();
		order1.setTitle("张三的订单1");
		order1.setUser(user);
		
		Orders order2 = new Orders();
		order2.setTitle("张三的订单2");
		order2.setUser(user);
		
		user.getOrders().add(order1); // inverse="false"会出现update
		user.getOrders().add(order2); // inverse="false"会出现update
		
		/**
		 * 执行save操作时,先插入user,然后插入orders
		 * 由于在一和多的维护关系会出现update,所以最好设置inverse="false"
		 * 这样子插入数据就不会出现update的语句
		 */
		session.save(user);
		session.save(order1);
		session.save(order2);
		
	}
	
	/**
	 * 读取数据
	 */
	@Test
	public void testGet() {
		// 多的一端使用延迟加载
		User user = (User) session.get(User.class, 1);
		System.out.println(user);
		System.out.println(user.getOrders());
	}

}


你可能感兴趣的文章