`

Hibernateday04一对多的自身相关(从经理找员工)

 
阅读更多

从经理找员工{1:*}
class Emp{
 Integer empNo  
 String eName                    
 String job                       
 Integer mrg        
 Date  hireDate                      
 Double sal   
 Double comm                         
 Integer deptNo
 Set<Emp> undering;//关系属性
}

 

1.建表R,以Oracle提供的emp表为例、

EMPNO                          NOT NULL NUMBER(4)                                                                                                                                                                                     
ENAME                                   VARCHAR2(10)                                                                                                                                                                                  
JOB                                     VARCHAR2(9)                                                                                                                                                                                   
MGR                                     NUMBER(4)                                                                                                                                                                                     
HIREDATE                                DATE                                                                                                                                                                                          
SAL                                     NUMBER(7,2)                                                                                                                                                                                   
COMM                                    NUMBER(7,2)                                                                                                                                                                                   
DEPTNO                                  NUMBER(2)        

 2.在com.jsu.hb.pojo包中提供实体类Emp2.java

package com.jsu.hb.pojo;

import java.util.Date;
import java.util.HashSet;
import java.util.Set;
/*从经理查员工*/
public class Emp2 {
	private Integer empNo;
	private String  ename;
	private String job;
	private Date hireDate;
	private Double sal;
	private Double comm;
	private Integer deptNo;
	private Integer mgr;
	/* 关系属性 */
	private Set<Emp2> emps = new HashSet<Emp2>();
	public Integer getEmpNo() {
		return empNo;
	}
	public void setEmpNo(Integer empNo) {
		this.empNo = empNo;
	}
	public String getEname() {
		return ename;
	}
	public void setEname(String ename) {
		this.ename = ename;
	}
	public String getJob() {
		return job;
	}
	public void setJob(String job) {
		this.job = job;
	}
	public Date getHireDate() {
		return hireDate;
	}
	public void setHireDate(Date hireDate) {
		this.hireDate = hireDate;
	}
	public Double getSal() {
		return sal;
	}
	public void setSal(Double sal) {
		this.sal = sal;
	}
	public Double getComm() {
		return comm;
	}
	public void setComm(Double comm) {
		this.comm = comm;
	}
	public Integer getDeptNo() {
		return deptNo;
	}
	public void setDeptNo(Integer deptNo) {
		this.deptNo = deptNo;
	}
	public Integer getMgr() {
		return mgr;
	}
	public void setMgr(Integer mgr) {
		this.mgr = mgr;
	}
	public Set<Emp2> getEmps() {
		return emps;
	}
	public void setEmps(Set<Emp2> emps) {
		this.emps = emps;
	}
	
	
}

 3.M 提供映射文件emp2.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">
<hibernate-mapping package="com.jsu.hb.pojo"><!-- 配置当前xml的默认包路径 -->
	<class name="Emp2" table="emp">
		<!-- 配置主键信息 -->
		<id name="empNo" column="empno" type="java.lang.Integer">
			<generator class="increment"></generator>
		</id>
		<!-- 配置普通属性 -->
		<property name="ename" column="ename" type="string"></property><!--hibernate定义的类型  -->
		<property name="job" column="job"></property><!--type可以省略  -->
		<property name="hireDate" column="hiredate" type="java.util.Date"></property>
		<property name="sal" column="sal"></property>
		<property name="comm" column="comm"></property>
		<property name="deptNo" column="deptno"></property>
		<property name="mgr" column="mgr"></property>
		<!-- 关系属性 一个经理 对应多个员工-->
		<set name="emps">
			<key column="mgr" />
			<one-to-many class="Emp2" />
		</set>
	</class>
</hibernate-mapping>

 4.在hibernate.cfg.xml文件中对映射文件进行注册

<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
	<session-factory> 
		<!-- show_sql:是否显示hibernate执行的SQL语句,默认为false -->
		<property name="show_sql">true</property>
		<!-- show_sql:是否显示hibernate执行格式化输出的SQL语句,默认为false -->
		<property name="format_sql">true</property>
		<!-- 配置与数据库连接的参数 -->
		<property name="connection.driver_class">oracle.jdbc.OracleDriver</property>
		<property name="connection.url">jdbc:oracle:thin:@127.0.0.1:1521:orcl</property>
		<property name="connection.username">scott</property>
		<property name="connection.password">tiger</property>
		<!-- 2.自身属性相关的配置
			dialect:方言
			hibernate根据dialect的配置进行特定数据性能方面的调优
		 -->
		<property name="dialect">org.hibernate.dialect.Oracle9iDialect</property>
<!--对映射文件进行注册-->
		<mapping resource="com/jsu/hb/pojo/emp2.hbm.xml"></mapping>
	</session-factory>
</hibernate-configuration>

 5.提供工具类获得session,HibernateUtil.java

package com.jsu.hb.util;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class HibernateUtil {
	private static SessionFactory sf;
	private static ThreadLocal<Session> tl= new ThreadLocal<Session>();
	static{
		try{
				Configuration cfg = new Configuration();
				cfg.configure();
				sf=cfg.buildSessionFactory();
		}catch(Exception e){
			e.printStackTrace();
		}
	}
	public static Session openSession(){
		return sf.openSession();
	}
	public static Session getCurrentSession(){
		Session session = tl.get();//先从储存的线程中查找
		if(session==null){
			session=openSession();
			tl.set(session);
			return session;
		}
		return session;
	}
}

 6.提供测试类TestfindEmp.java

package com.jsu.hb.test;

import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.Test;

import com.jsu.hb.pojo.Emp2;
import com.jsu.hb.util.HibernateUtil;

public class TestfindEmp {
	@Test
	public void findEmp(){
		Session session = HibernateUtil.getCurrentSession();
		Transaction tx = session.getTransaction();
		tx.begin();
		// 查找员工
		Emp2 e = (Emp2) session.get(Emp2.class, 7698);
		System.out.println("员工个数:"+e.getEmps().size());
		tx.commit();
	}
}
 
分享到:
评论

相关推荐

    Hibernate学习笔记

    3. **关系映射(Relationship Mapping)**:包括一对一(OneToOne)、一对多(OneToMany)、多对一(ManyToOne)、多对多(ManyToMany)关系。 ### 五、Hibernate操作 1. **对象状态**:Hibernate对象有瞬时态...

    HQL学习大全.rar

    标题中的“HQL学习大全.rar”表明这是一份关于HQL(Hibernate Query Language)的综合学习资源包。HQL是Hibernate框架中用于操作对象关系映射(ORM)的查询语言,它模仿了SQL的语法,但操作的是面向对象的数据。 ...

    hibernate框架配置源码

    一级缓存是Session级别的,每个Session都有自己的缓存;二级缓存是SessionFactory级别的,可被多个Session共享。 8. **事务处理**: Hibernate支持事务管理,通常会使用`Transaction`对象来包裹一组数据库操作,...

    Hibernate环境搭建案例

    在`HibernateDay1`这个压缩包中,可能包含了相关的示例代码、配置文件和教程文档,你可以根据这些资源进行学习和实践。通过逐步理解并实践这些步骤,你将能够掌握Hibernate的基本用法,为进一步深入学习和应用ORM...

    基于微信小程序的校园论坛;微信小程序;云开发;云数据库;云储存;云函数;纯JS无后台;全部资料+详细文档+高分项目.zip

    【资源说明】 基于微信小程序的校园论坛;微信小程序;云开发;云数据库;云储存;云函数;纯JS无后台;全部资料+详细文档+高分项目.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

    单电阻采样 基于单电阻采样的相电流重构算法 keil完整工程 单电阻采样 f103的单电阻,完整工程,带文档,带硬件资料 f3平台的单电阻完整工程,代码详细注释 还有微芯的单电阻smo代码加文档

    单电阻采样 基于单电阻采样的相电流重构算法 keil完整工程。 单电阻采样 f103的单电阻,完整工程,带文档,带硬件资料。 f3平台的单电阻完整工程,代码详细注释。 还有微芯的单电阻smo代码加文档 具体如截图请看下

    jQuery左侧导航右侧tab页面切换.zip

    jQuery左侧导航右侧tab页面切换

    数据结构之哈希查找方法

    哈希查找

    五相电机邻近四矢量SVPWM模型-MATLAB-Simulink仿真模型包括: (1)原理说明文档(重要):包括扇区判断、矢量作用时间计算、矢量作用顺序及切时间计算、PWM波的生成; (2)输出部分仿

    五相电机邻近四矢量SVPWM模型_MATLAB_Simulink仿真模型包括: (1)原理说明文档(重要):包括扇区判断、矢量作用时间计算、矢量作用顺序及切时间计算、PWM波的生成; (2)输出部分仿真波形及仿真说明文档; (3)完整版仿真模型:Simulink仿真模型; 注意,只包含五相电机邻近四矢量SVPWM算法,并非五相电机双闭环矢量控制,如果想要五相电机双闭环矢量控制资料,另一个链接。 资料介绍过程十分详细

    法码滋.exe法码滋2.exe法码滋3.exe

    法码滋.exe法码滋2.exe法码滋3.exe

    java毕设项目之教务信息平台的设计与实现+jsp(完整前后端+说明文档+mysql+lw).zip

    项目包含完整前后端源码和数据库文件,均测试可正常运行 环境说明: 开发语言:Java 框架:ssm,mybatis JDK版本:JDK1.8 数据库:mysql 5.7 数据库工具:Navicat11 开发软件:eclipse/idea Maven包:Maven3.3 部署容器:tomcat7

    基于Python+OpenCv的人手分割算法

    算法允许用户在图像上自行划定标签,并对这些区域内的图像进行肤色检测和处理;最后在一个PyQt窗口中显示处理后的三张图片,分别为带标签图片,二值化图片,膨胀后图片。

    浪漫节日代码 - 爱心代码、圣诞树代码

    内容概要: 本资料包含了一系列用于庆祝浪漫节日的创意代码,主要包括爱心代码和圣诞树代码。这些代码可以生成视觉上吸引人的图案和动画,用于在屏幕上展示爱心和圣诞树,增加节日气氛。爱心代码可以用于表达爱意,而圣诞树代码则适合在圣诞节期间使用,为用户带来节日的欢乐和视觉享受。 适用人群: 本资料适用于以下人群: 程序员和开发者,他们希望在项目中添加节日元素或为特别场合创造个性化的视觉效果。 网页设计师,他们需要为网站或应用程序添加节日主题的装饰。 技术爱好者和DIY爱好者,他们喜欢通过编程来庆祝节日或为朋友和家人制作特别的礼物。 实现:可直接运行python程序。

    疫情隔离管理-JAVA-基于springboot + vue的疫情隔离管理系统设计与实现(毕业论文)

    1. 患者信息与隔离状态管理 患者基本信息录入:对于疑似、确诊或密切接触者患者,系统记录其基本信息,包括姓名、年龄、性别、联系方式、住址等。 疫情风险评估:通过问卷或医务人员评估,系统对患者进行风险评估,判断是否需要隔离、隔离的级别(如轻症、中症、重症等)。 隔离状态管理:记录患者的隔离状态(如隔离中、已解除隔离、转入ICU等),并能够实时更新隔离状态变化。 隔离病房分配:根据患者的病情、感染风险和病房资源,系统自动分配适当的隔离病房或床位,避免交叉感染。 2. 隔离病房与环境管理 病房信息管理:系统对每个隔离病房进行实时监控,包括病房的床位使用情况、设备设施、清洁消毒状况等,确保每个病房的隔离效果。 空气流通与环境消毒管理:记录隔离病房的空气流通情况、消毒记录、物品消耗等,确保符合疫情防控要求。 设备与物资分配:针对隔离病房的特殊需求,系统可以自动化管理医疗设备(如氧气、呼吸机等)与防护物资(如口罩、手套、防护服等)的分配与库存管理。 3. 医护人员防护与工作管理 医护人员排班与防护管理:为隔离病房的医护人员进行特殊排班,避免交叉感染,并根据需要分配适当的防护装备,如全身防护服、N9

    富芮坤FR8003作为主机连接FR8003抓包文件20241223-135206.pcapng

    适配文章:https://editor.csdn.net/md?not_checkout=1&spm=1011.2415.3001.6217&articleId=144663667 富芮坤FR8003作为主机连接FR8003二:官方代码主从的UUID和att_idx

    德普微一级代理 DP3145D SOT23-6 USB PD 协议单口控制器

    内容概要:文章介绍了USB PD协议单口控制器DP3145D的技术特点、主要功能和应用场景。DP3145D支持USB Type-C和USB Power Delivery(PD)3.1协议,具备多种配置选项,最高输出功率45W。它集成了CV环路光耦驱动电路、反馈网络电阻以及多项保护措施,适用于ACDC适配器等USB充电设备。 适合人群:电子工程师、电源产品设计师和技术研究人员。 使用场景及目标:主要用于设计和开发支持USB PD协议的ACDC适配器和充电设备,实现高效、安全的充电解决方案。 阅读建议:重点关注DP3145D的具体技术参数、功能特点和典型应用实例,结合自身需求进行产品选型和设计。

    VBA视频教程 0005

    VBA视频教程 05

    基于Spring Boot框架的网上蛋糕销售系统_30z8r428_231-wx.zip

    基于Spring Boot框架的网上蛋糕销售系统_30z8r428_231-wx.zip

    simulink线性马达H-infinity控制

    matlab

    蜡笔小新-去掉动效.zip

    蜡笔小新-去掉动效.zip

Global site tag (gtag.js) - Google Analytics