- 浏览: 606634 次
文章分类
- 全部博客 (411)
- 常用工具 (21)
- 喜好 (14)
- 英语 (3)
- java (51)
- ext (4)
- css (44)
- php (34)
- window (7)
- jquery (21)
- js (31)
- struts (4)
- tomcat (1)
- struts2 (11)
- 网络 (4)
- c# (7)
- linux (27)
- oracle (15)
- tag标签 (5)
- 生成静态页面 (6)
- sql (12)
- hibernate (13)
- DesignPattern (3)
- spring (2)
- flex (17)
- excel应用 (1)
- 报表 (2)
- 业界 (2)
- 数据建模 (1)
- 平板 (1)
- ppt (1)
- rich (1)
最新评论
-
youngdze:
受教了,谢谢!
十步解决php utf-8编码 -
DiLiya:
感谢你的讲解;帮了大忙了!
解决-innerHTML无法在TBODY中使用 -
eppen:
强的没话说。帮了大忙。感谢goby2008 ,感谢google ...
解决-innerHTML无法在TBODY中使用 -
cxs4808:
rr
flex 设计模式 -
liuxingvsyou:
3个jQuery弹出窗口插件
Room.java
package com.goby.Hibernate.bean; import java.util.Set; public class Room { private int id; private String address; private Set users; public Set getUsers() { return users; } public void setUsers(Set users) { this.users = users; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getAddress() { return address; } public void setAddress(String address) { this.address = address; } }
User.java
package com.goby.Hibernate.bean; public class User { private int id; private String name; private Room room; public Room getRoom() { return room; } public void setRoom(Room room) { this.room = room; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
Room.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.goby.Hibernate.bean"> <class name="Room" table="t_room"> <id name="id"> <generator class="native"></generator> </id> <property name="address"></property> <set name="users" table ="user" cascade="all" inverse="true"> <key column="room_id"/> <one-to-many class="com.goby.Hibernate.bean.User"/> </set> </class> </hibernate-mapping>
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"> <hibernate-mapping package="com.goby.Hibernate.bean"> <class name="User" table="t_user"> <id name="id"> <generator class="native"/> </id> <property name="name"/> <many-to-one name="room" column="room_id" cascade="all"/> </class> </hibernate-mapping>
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 > <property name="hibernate.connection.url">jdbc:mysql://localhost/hibernate_OnetoMany</property> <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property> <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> <property name="hibernate.connection.username">root</property> <property name="hibernate.connection.password">seebig</property> <property name="hibernate.show_sql">true</property> <property name="hibernate.format_sql">false</property> <mapping resource="com/goby/Hibernate/bean/User.hbm.xml" /> <mapping resource="com/goby/Hibernate/bean/Room.hbm.xml" /> </session-factory> </hibernate-configuration>
Test.java
package test; import java.util.HashSet; import java.util.Iterator; import java.util.Set; import junit.framework.TestCase; import org.hibernate.Session; import com.goby.Hibernate.bean.HibernateUtils; import com.goby.Hibernate.bean.Room; import com.goby.Hibernate.bean.User; /* * 一对多 * */ public class test extends TestCase { public void testSave(){ Session session = null; try{ session = HibernateUtils.getSession(); session.beginTransaction(); User user1 = new User(); user1.setName("菜10"); User user2 = new User(); user2.setName("周杰伦"); User user3 = new User(); user3.setName("黎明"); Set setuser1 = new HashSet(); setuser1.add(user1); setuser1.add(user2); Set setuser2 = new HashSet(); setuser2.add(user3); Room room1 = new Room(); room1.setAddress("第一房间"); room1.setUsers(setuser1); Room room2 = new Room(); room2.setAddress("第二房间"); room2.setUsers(setuser2); session.save(room1); session.save(room2); session.getTransaction().commit(); }catch(Exception ex){ ex.printStackTrace(); session.getTransaction().rollback(); }finally{ HibernateUtils.closeSession(session); } } /* * 从ROOM类中获取数据 */ public void testload(){ Session session = null; try{ session = HibernateUtils.getSession(); session.beginTransaction(); Room room = (Room)session.load(Room.class, 1); System.out.println("room.address=" + room.getAddress()); for(Iterator iter = room.getUsers().iterator();iter.hasNext();){ User user = (User)iter.next(); System.out.println("User.name="+user.getName()); } session.getTransaction().commit(); }catch(Exception ex){ ex.printStackTrace(); session.getTransaction().rollback(); }finally{ HibernateUtils.closeSession(session); } } /* * 从User类中获取数据 */ public void testload2(){ Session session = null; try{ session = HibernateUtils.getSession(); session.beginTransaction(); User user = (User)session.load(User.class, 3); System.out.println("user.name"+user.getName()); System.out.println("room.address"+user.getRoom().getAddress()); session.getTransaction().commit(); }catch(Exception ex){ ex.printStackTrace(); session.getTransaction().rollback(); }finally{ HibernateUtils.closeSession(session); } } }
发表评论
-
nested exception is org.hibernate.TransactionException: JDBC rollback failed
2009-11-26 15:03 3238nested exception is org.hiberna ... -
hibernate 批量删除
2009-11-26 08:31 1124public int deleteBrands(Long[] ... -
hibernate 关系映射指南
2009-11-26 08:29 814在网上看到一个比较好的O/R指南http://www.xyla ... -
用hibernate作为持久层,update是出现了重复记录
2009-11-26 08:28 965用hibernate作为持久层,u ... -
采用编程式事务
2009-08-08 15:00 717采用编程式事务 1、getCurrentSession()与 ... -
hibernate笔记(六) 多对多
2009-07-24 14:15 713User.java package com.goby. ... -
hibernate笔记(四) 一对一 (唯一外键关联)
2009-07-24 14:01 744Room.hbm.xml <?xml version= ... -
hibernate笔记(三) 一对一 (主键关联)
2009-07-23 17:32 850Room.java package com.goby.Hib ... -
hibernate笔记(一)_补充 建立表代码
2009-07-23 14:11 779建立表代码 :Export.java package com ... -
hibernate笔记(二) 多对一 Many to One
2009-07-23 14:09 789User.java package com.goby.Hib ... -
hibernate笔记(一)_补充 Hibnerateutils
2009-07-23 10:53 738HibernateUtils.java package ... -
hibernate笔记(一)Hibernate_First
2009-07-23 10:45 701User.java package com.goby.Hib ...
相关推荐
4. **映射策略**:Hibernate提供了多种映射策略,用于处理对象和数据库表之间的映射关系,包括一对一、一对多、多对一、多对多等。这些策略使得开发者可以根据不同的业务需求选择最适合的映射方式。 5. **数据库...
此外,可能还会涉及到 Hibernate 的检索策略,如 HQL(Hibernate Query Language)查询、Criteria 查询和 Criteria API,以及一对多、多对一、一对一和多对多的关联映射。 【pdf讲义】通常会以更加系统和结构化的...
最后,笔记可能还会涵盖一些高级主题,如多对一、一对多、多对多的关系映射,懒加载和立即加载策略,以及自定义类型和事件监听器等。这些内容能够帮助开发者灵活地应对各种复杂的数据库设计和业务场景。 总的来说,...
笔记将阐述如何配置和使用这些集合,以及如何处理一对多、一对一、多对一、多对多的关联关系。 9. 性能优化:最后,笔记会探讨一些Hibernate的性能优化技巧,如批处理、缓存策略、延迟加载的合理使用等,以提高应用...
6. **关联映射**:深入探讨一对一、一对多、多对一、多对多等各种关联映射的配置及使用,以及懒加载和立即加载的概念。 7. **缓存机制**:介绍Hibernate的缓存层次结构,包括一级缓存(Session缓存)和二级缓存,...
《Hibernate入门:第一天笔记详解》 Hibernate,作为Java领域中著名的ORM(Object-Relational Mapping)框架,极大地简化了数据库操作,让开发者可以更加专注于业务逻辑而不是底层的数据访问。本文将基于第一天学习...
- **关系映射**:讲解一对一、一对多、多对多等关系类型的映射方法。 - **Hibernate查询(HQL)**:学习Hibernate Query Language的基础及高级特性。 - **在Struts基础上继续完善BBS2006**:结合Struts框架实现BBS应用...
3. **关系映射**:@OneToOne、@OneToMany、@ManyToOne、@ManyToMany等注解用于处理一对一、一对多、多对一和多对多的关系。 **四、Session与Transaction** 1. **SessionFactory**:负责创建Session实例,是线程安全...
在高级主题中,笔记会涉及一对多、多对一、一对一和多对多的关系映射。这些关系映射是ORM的核心特性,使得Java对象与数据库表之间的关联得以建立。此外,还会讲解懒加载(Lazy Loading)和即时加载(Eager Loading)...
本文将深入探讨Hibernate中的一对多关系,并重点解析`inverse`属性的作用及其应用。 一对多关系是数据库设计中常见的关联类型,例如一个用户可以拥有多个订单,一个班级可以包含多个学生等。在Hibernate中,通过...
### Hibernate笔记 #### 一、概述 Hibernate 是一个开源的对象关系映射(ORM)框架,它简化了Java应用程序与数据库之间的交互过程。通过使用Hibernate,开发者可以将对象模型与关系型数据库模型进行映射,从而避免...
hibernate中一对一,一对多,多对多关系的配置,延迟加载,cascade,inverse hibernate查询方式概述,HQL查询,QBC查询,分页,结果集封装方式 ,高级查询 查询的优化,一级缓存,二级缓存,批量查询,注解方式
在本篇《Hibernate学习笔记》中,我们将深入探讨Hibernate这一流行的Java对象关系映射(ORM)框架。Hibernate允许开发者以面向对象的方式处理数据库操作,极大地简化了数据存取的复杂性。以下是一些关键知识点: 1....
- **映射机制**:包括基础映射(类与表的映射)、继承映射(单表继承、多表继承)、组件映射(对象内部结构的映射)以及集合映射(一对多、多对一、多对多等关系的映射)。 3. **HQL查询**: - Hibernate Query ...
5. **二级缓存**:Hibernate支持缓存机制,通过插件如Ehcache,可以提高数据访问效率,减少对数据库的直接访问。 6. **实体生命周期**:Hibernate定义了对象的四种状态(瞬时态、持久态、托管态、脱管态),理解...