关键代码:

<!-- 
    单向多对一映射
    name:多这一端属性的名字
    class:一那一端对应的类名
    column:一那一端在多的一端数据表中外键的名字
-->
<many-to-one name="user" class="User" column="USER_ID">
</many-to-one>


详细:

User.java:

package com.shuoeasy.test;

public class User {
	private int id;
	private String userName;
	
	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;
	}
	@Override
	public String toString() {
		return "User [id=" + id + ", userName=" + userName + "]";
	}
	
}

Orders.java:

package com.shuoeasy.test;

public class Orders {
	private int id;
	private User user;
	private String title;
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public User getUser() {
		return user;
	}
	public void setUser(User user) {
		this.user = user;
	}
	public String getTitle() {
		return title;
	}
	public void setTitle(String title) {
		this.title = title;
	}
	@Override
	public String toString() {
		return "Order [id=" + id + ", user=" + user + ", title=" + title + "]";
	}
	
	
}

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>
		
	</class>
</hibernate-mapping>

Orders.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  package="com.shuoeasy.test">
	<class name="Orders" table="Orders">
		<id name="id" type="int">
			<column name="ID" />
			<!-- 指定主键的生成方式,native:使用数据库本地方式 -->
			<generator class="native" />
		</id>
		<property name="title" type="java.lang.String">
			<column name="TITLE" />
		</property>
		
		<!-- 单向多对一映射 
		name:多这一端属性的名字
		class:一那一端对应的类名
		column:一那一端在多的一端数据表中外键的名字
		-->
		<many-to-one name="user" class="User" column="USER_ID">
	 	</many-to-one>
		
	</class>
</hibernate-mapping>

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);
		
		// 按照父子数据的顺序插入,生成三条insert
		session.save(user);
		session.save(order1);
		session.save(order2);
		
		/*
		 * 打乱顺序插入,生成三条insert,两条update。
		 * 所以不建议打乱顺序
		session.save(order1);
		session.save(order2);
		session.save(user);*/
	}
	
	/**
	 * 读取数据
	 */
	@Test
	public void testGet() {
		Orders order = (Orders) session.get(Orders.class, 1);
		System.out.println(order); // 使用的对象的时候才会懒加载user对象
	}
	
	/**
	 * 修改
	 */
	@Test
	public void testUpdate(){
		Orders order = (Orders) session.get(Orders.class, 1);
		order.getUser().setUserName("李四");
		session.save(order);
	}
	
	/**
	 * 删除
	 */
	@Test
	public void testDelete(){
		// 删除会失败,默认不能删除级联对象
		User user = (User) session.get(User.class, 1);
		session.delete(user);
	}
}


生产的数据库表结构

user表:

blob.png

orders表:

blob.png

你可能感兴趣的文章