博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Hibernate5-1对多(1:n)-fetch="join"
阅读量:6619 次
发布时间:2019-06-25

本文共 4647 字,大约阅读时间需要 15 分钟。

1.创建项目,项目名称hibernatedemo22,目录结构如图所示

2.在项目中创建lib目录存储jar文件,目录结构如图所示

3.在src目录中创建实体类Forum,包名(com.mycompany.demo.bean),如图所示

4.实体类Forum的内容如下

package com.mycompany.demo.bean;import java.util.Set;public class Forum {	private int fid;	private String name;	private Set
 forumPosts; public int getFid() { return fid; } public void setFid(int fid) { this.fid = fid; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Set
 getForumPosts() { return forumPosts; } public void setForumPosts(Set
 forumPosts) { this.forumPosts = forumPosts; }}

5.在src目录中创建实体类Forum的映射文件Forum.hbm.xml,包名(com.mycompany.demo.bean),如图所示

6.映射文件Forum.hbm.xml的内容如下

 
   
      
         This class contains the forum detail.             
      
      
         
                  
      
            
      
      
      
         

7.在src目录中创建实体类ForumPost,包名(com.mycompany.demo.bean),如图所示

8.实体类ForumPost的内容如下

package com.mycompany.demo.bean;public class ForumPost {	private int pid;	private String subject;	private Forum forum;	public int getPid() {		return pid;	}	public void setPid(int pid) {		this.pid = pid;	}	public String getSubject() {		return subject;	}	public void setSubject(String subject) {		this.subject = subject;	}	public Forum getForum() {		return forum;	}	public void setForum(Forum forum) {		this.forum = forum;	}}

9.在src目录中创建实体类ForumPost的映射文件ForumPost.hbm.xml,包名(com.mycompany.demo.bean),如图所示

10.映射文件ForumPost.hbm.xml的内容如下

 
   
      
         This class contains the forumpost detail.             
      
      
         
                  
      
            
      
      
from Forum f left outer join fetch f.forumPosts

11.在src目录中创建工具类 HbnUtil,包名(com.mycompany.demo.util),如图所示

12.工具类 HbnUtil的内容如下

package com.mycompany.demo.util;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.cfg.Configuration;public class HbnUtil {	private static SessionFactory sessionFactory;		public static Session getSession(){		if(sessionFactory == null || sessionFactory.isClosed()){			sessionFactory = new Configuration().configure().buildSessionFactory();		}				return sessionFactory.getCurrentSession();	}}

13.在src目录中创建Hibernate的配置文件hibernate.cfg.xml,如图所示

14.Hibernate的配置文件hibernate.cfg.xml的内容如下

   
   
   
org.hibernate.dialect.MySQLDialect    
   
com.mysql.jdbc.Driver    
   
jdbc:mysql://localhost:3306/test    
   
      root        
   
   
   
update    
   
true    
   
true    
   
thread           
   
   org.hibernate.c3p0.internal.C3P0ConnectionProvider     
   
   

15.在项目中创建test目录存储测试文件,文件名称TestApp,包名(com.mycompany.demo.bean),目录结构如图所示

16.TestApp测试类的内容如下

package com.mycompany.demo.bean;import java.util.HashSet;import java.util.List;import java.util.Set;import org.hibernate.Criteria;import org.hibernate.Session;import org.hibernate.sql.JoinType;import org.junit.Before;import org.junit.Test;import com.mycompany.demo.util.HbnUtil;public class TestApp {		private Session session;		@Before	public void init(){		session = HbnUtil.getSession();	}		/*	 * 一对多双向关联-添加	 * 需要设置Forum.hbm.xml中的Set属性为cascade="all"	 */	@Test	public void testOneToManyAdd(){		try {			session.beginTransaction();						ForumPost forumPost1 = new ForumPost();			forumPost1.setSubject("A");						ForumPost forumPost2 = new ForumPost();			forumPost2.setSubject("B");						Set
 forumPosts = new HashSet
(); forumPosts.add(forumPost1); forumPosts.add(forumPost2); Forum forum = new Forum(); forum.setName("foruma"); forum.setForumPosts(forumPosts); session.save(forum); session.getTransaction().commit(); } catch (Exception e) { session.getTransaction().rollback(); e.printStackTrace(); } } /*  * 一对多双向关联-fetch="join"  */ @Test public void testFetchForJoin(){ try { session.beginTransaction(); Forum forum = session.get(Forum.class, 10); Set
 forumPosts = forum.getForumPosts(); for (ForumPost forumPost : forumPosts) { System.out.println(forumPost.getSubject()); } session.getTransaction().commit(); } catch (Exception e) { session.getTransaction().rollback(); e.printStackTrace(); } }}

本文转自 素颜猪 51CTO博客,原文链接:http://blog.51cto.com/suyanzhu/1912318

转载地址:http://peupo.baihongyu.com/

你可能感兴趣的文章
Python高效编程(一)
查看>>
导出excel功能示例+传参序列化示例
查看>>
TiDB 在转转的业务实战
查看>>
WebViewJavascriptBridge
查看>>
n PK nvm 方法使用
查看>>
新手快速上手webpack4打包工具的使用
查看>>
什么样的程序员能够月薪过万?
查看>>
js中的错误处理(try...catch...finally,异步错误)
查看>>
1024程序员节最新福利之2018最全大数据资料集合
查看>>
使用OpenGL绘制简易三角形
查看>>
封装轮播图
查看>>
作为一个Java 程序员 你应该会什么
查看>>
ES7-ES9新特性概述
查看>>
Java多线程编程笔记3:synchronized同步语句块
查看>>
Github变身网络硬盘
查看>>
js获取当前时间(昨天、今天、明天)
查看>>
用于前端开发的webpack4配置[带注释]
查看>>
package.json依赖包版本升级
查看>>
区块链主流共识算法
查看>>
浏览器中的事件流和node中处理时间循环的分析
查看>>