Hibernate入门(七)一对多入门案例
一对多
场景模拟:用户(一)对订单(多)
1.建表
创建客户表,字段有:客户id,客户姓名,客户性别,客户年龄,客户年纪,客户电话。
创建订单表,字段有:订单编号,明细编号,客户编号(外键)
DROP TABLE IF EXISTS ordersA;
DROP TABLE IF EXISTS customerA;
CREATE TABLE customerA(
cust_id TINYINT PRIMARY KEY AUTO_INCREMENT,
cust_name VARCHAR(30),
cust_gender CHAR(5),
cust_age SMALLINT,
cust_phone VARCHAR(20)
); CREATE TABLE ordersA(
order_id VARCHAR(50) PRIMARY KEY,
detail_id VARCHAR(50),
cust_order_id TINYINT,
CONSTRAINT fk_customerA_ordersA FOREIGN KEY(cust_order_id) REFERENCES customerA(cust_id) ON DELETE CASCADE
);
2.创建项目,配置hibernate.cfg.xml主配置文件
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuration>
<session-factory> <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql:///test</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">123456</property> <property name="hibernate.show_sql">true</property>
<property name="hibernate.format_sql">true</property>
<property name="hibernate.hbm2ddl.auto">update</property>
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property> <!-- 指定session与当前线程绑定 -->
<property name="hibernate.current_session_context_class">thread</property> </session-factory>
</hibernate-configuration>
3.创建实体
创建用户实体类:基本属性+配置一对多的属性(set集合存储多个订单)
创建订单实体类:基本属性+配置多对一的属性(Customer类存储客户实体)
package deep.domain; import java.io.Serializable;
import java.util.HashSet;
import java.util.Set; /**
* 客户实体类
* @author DeepSleeping
*
*/
public class Customer implements Serializable { private static final long serialVersionUID = 1L;
private Integer cust_id;
private String cust_name;
private String cust_gender;
private Integer cust_age;
private String cust_phone; /*
* 一对多
* */
private Set<Order> ods = new HashSet<Order>(); public Integer getCust_id() {
return cust_id;
} public void setCust_id(Integer cust_id) {
this.cust_id = cust_id;
} public String getCust_name() {
return cust_name;
} public void setCust_name(String cust_name) {
this.cust_name = cust_name;
} public String getCust_gender() {
return cust_gender;
} public void setCust_gender(String cust_gender) {
this.cust_gender = cust_gender;
} public Integer getCust_age() {
return cust_age;
} public void setCust_age(Integer cust_age) {
this.cust_age = cust_age;
} public String getCust_phone() {
return cust_phone;
} public void setCust_phone(String cust_phone) {
this.cust_phone = cust_phone;
} public Set<Order> getOds() {
return ods;
} public void setOds(Set<Order> ods) {
this.ods = ods;
} }
package deep.domain; import java.io.Serializable; /**
* 订单实体类
* @author DeepSleeping
*
*/
public class Order implements Serializable{ private static final long serialVersionUID = 1L;
private String order_id;
private String detail_id; /*
* 多对一
*/
private Customer cst; public String getOrder_id() {
return order_id;
}
public void setOrder_id(String order_id) {
this.order_id = order_id;
}
public String getDetail_id() {
return detail_id;
}
public void setDetail_id(String detail_id) {
this.detail_id = detail_id;
}
public Customer getCst() {
return cst;
}
public void setCst(Customer cst) {
this.cst = cst;
} }
4.配置实体的映射文件:Customer.hbm.xml,Order.hbm.xml
Customer.hbm.xml中的set标签对中:
set:存储多的一方的集合 name:存储多的一方的集合属性名
key标签对:配置外键
column:是数据库中外键的字段名(注意这里写的名一定要与后面多方中配置外键的名称一致,否则就会创建多个外键)
<one-to-many> 是表示,我这里是一对多,对的多的一方的实体类的路径是:class = "order"(这里只写order是因为在配置文件中我已经用package定位到实体类的包下了)
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="deep.domain">
<class name="Customer" table="customera">
<id name="cust_id" column = "cust_id">
<generator class="native"></generator>
</id> <property name="cust_name" column = "cust_name"></property>
<property name="cust_gender" column = "cust_gender"></property>
<property name="cust_age" column = "cust_age"></property>
<property name="cust_phone" column = "cust_phone"></property> <!-- 配置一对多属性 -->
<set name="ods">
<key column="cust_order_id"></key>
<one-to-many class="Order"/>
</set> </class> </hibernate-mapping>
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="deep.domain">
<class name="Order" table="ordersa">
<id name="order_id" column = "order_id">
<generator class="uuid"></generator>
</id> <property name="detail_id" column = "detail_id"></property> <!-- 配置多对一属性 -->
<many-to-one name="cst" column="cust_order_id" class="Customer"/>
</class>
</hibernate-mapping>
5.在主配置文件中引入两个实体对应的映射文件
<mapping resource="deep/domain/Customer.hbm.xml"/>
<mapping resource="deep/domain/Order.hbm.xml"/>
6.添加订单到客户id为1的客户中
package deep.test; import java.util.UUID; import org.hibernate.Session;
import org.junit.Test; import deep.common.HibernateUtils;
import deep.domain.Customer;
import deep.domain.Order; public class TestClass { /**
* 添加订单到客户
*/
@Test
public void fun(){ Session session = HibernateUtils.getSession();
session.getTransaction().begin(); try {
//获取客户 持久
Customer cst = session.get(Customer.class, 1);
//新建订单 瞬时
Order od = new Order();
od.setOrder_id(UUID.randomUUID().toString());
od.setDetail_id(UUID.randomUUID().toString());
//表达客户和订单的关系
cst.getOds().add(od);
//表达订单和客户的关系
od.setCst(cst);
//持久化订单
session.save(od);
} catch (Exception e) {
session.getTransaction().rollback();
e.printStackTrace();
} session.getTransaction().commit();
}
}
添加订单成功!
Hibernate入门(七)一对多入门案例的更多相关文章
- 嵌入式OS入门笔记-以RTX为案例:六.RTX的任务调度
嵌入式OS入门笔记-以RTX为案例:六.RTX的任务调度 上一篇笔记介绍了一些绕开排程器(或调度程序,scheduler)来进行时间管理的一些小方法.这一篇详细介绍RTX的任务调度原理. RTX主要有 ...
- C语言第七讲,函数入门.
C语言第七讲,函数入门. 一丶了解面向过程和面向对象的区别. 为什么要先讲面向过程和面向对象的区别? 面向过程,就是什么都要自己做. 比如你要吃饭. 那么你得自己做饭. 面向对象, 面向对象就是我要 ...
- C#基础入门 七
C#基础入门 七 接口 由于C#语言不支持多重继承,所以可以使用接口模拟结构的继承,通过使用interface关键字,定义一个接口. interface USB { void Read(string[ ...
- Python爬虫入门七之正则表达式
在前面我们已经搞定了怎样获取页面的内容,不过还差一步,这么多杂乱的代码夹杂文字我们怎样把它提取出来整理呢?下面就开始介绍一个十分强大的工具,正则表达式! 1.了解正则表达式 正则表达式是对字符串操作的 ...
- 转 Python爬虫入门七之正则表达式
静觅 » Python爬虫入门七之正则表达式 1.了解正则表达式 正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符.及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串 ...
- Jmeter Web 性能测试入门 (七):Performance 测试中踩过 Jmeter 的坑
脚本运行的过程中,大量request抛error,但没有地方能够查看request是因为什么error的. 原因:Jmeter默认禁掉了运行过程中每个request的具体response信息收集,只保 ...
- Mybatis框架基础入门(七)--关联查询
1.一对一查询 1.1 使用resultType接收查询结果 修改pojo类 public class OrderUser extends order { private String usernam ...
- (多核DSP快速入门)SYS/BIOS入门
(多核DSP快速入门)SYS/BIOS入门 原创文章 转载请注册来源http://blog.csdn.net/tostq 系列教程目录:http://blog.csdn.net/tostq/art ...
- 毫无基础的人入门Python,Python入门教程
随着人工智能的发展,Python近两年也是大火,越来越多的人加入到Python学习大军,对于毫无基础的人该如何入门Python呢?这里整理了一些个人经验和Python入门教程供大家参考. 如果你是零基 ...
随机推荐
- 凌华Express CVC D2550 Win7 64-bit无法正常关机的解决办法
[问题现象]: 在Windows点击shutdown按钮后,显示器一直停在“正在关闭...”的界面上: 此时硬盘已经停止工作了: CPU没有发送S5信号,因此,主板上的电没有被切断: [解决办法]: ...
- My year of 2017
有一个姓罗的胖子,他说他有一个要坚持20年计划,第一年我真的不觉得什么,好比每天晚上都要刷牙每天早上都要吃早饭一样简单.实际几年走下来之后,发现能坚持下来真不是一件容易的事情,生活中总会有各种各样的事 ...
- 修复运行 tasklist 命令时提示 ERROR: Not found
最近碰到了一个脚本运行 tasklist 总是提示 ERROR: Not found,在这里找到了修复的方法 https://superuser.com/questions/1282867/windo ...
- iis发布后模板字体不能加载的解决方案
在使用ace模板的过程中就曾遇到过图标不显示的情况, 1.在iis和vs运行都不能显示图标,添加缺失的字体库后可以访问 2.把项目签入到阿里云时再一次失效,解决方法是添加Mime类型 .woff a ...
- jquery mobile Touch事件
Touch事件在用户触摸屏幕(页面)时触发 1.jquery mobile tap tap事件在用户敲击某个元素时触发 $("p").on("tap",fucn ...
- 省钱版----查找 IoT 设备TTL线序__未完待续
作者:仙果 原文来自:省钱版—-查找 IoT 设备TTL线序 省钱版----查找 IoT 设备TTL线序__未完待续 缘由 在IoT固件调试分析的过程中,建议首先在IoT设备的板子上焊接调试线,这是能 ...
- 项目文件与 SVN 资源库同步提示错误 Attempted to lock an already-locked dir
问题描述 之前为了图方便,在eclipse中直接把三个jsp文件复制到了eclipse中我新建的一个文件夹中,把svn版本号信息也带过来了,然后我又删除了这三个jsp文件,接着先把这三个jsp复制到桌 ...
- OutOfMemoryError 到底能不能被捕获?
感觉中,OutOfMemeryError(内存溢出错误) 是jvm抛出的异常,是不能被捕获的. 直到工作中真的遇到OOM异常,而且tomcat服务还一直对外提供服务. 那么问题来了: 1. OOM 到 ...
- Python开发之---PyCharm初体验
PyCharm 的初始设置(知道) 目标 恢复 PyCharm 的初始设置 第一次启动 PyCharm 新建一个 Python 项目 设置 PyCharm 的字体显示 PyCharm 的升级以及其他 ...
- Taro 多端开发的正确姿势:打造三端统一的网易严选(小程序、H5、React Native)
笔者所在的趣店 FED 早在去年 10 月份就已全面使用 Taro 框架开发小程序(当时版本为 1.1.0-beta.4),至今也上线了 2 个微信小程序.2 个支付宝小程序. 之所以选用 Taro, ...