经典hibernate教程,从入门到精通cstp-hibernate03(第三篇,共四篇)_第1页
经典hibernate教程,从入门到精通cstp-hibernate03(第三篇,共四篇)_第2页
经典hibernate教程,从入门到精通cstp-hibernate03(第三篇,共四篇)_第3页
经典hibernate教程,从入门到精通cstp-hibernate03(第三篇,共四篇)_第4页
经典hibernate教程,从入门到精通cstp-hibernate03(第三篇,共四篇)_第5页
已阅读5页,还剩25页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第六章,Hibernate的关联映射,回顾,下面这个异常是怎么回事?该怎么解决?,org.hibernate.MappingException: Unknown entity: com.aptech.jb.entity.TblUser at org.hibernate.impl.SessionFactoryImpl.getEntityPersister (SessionFactoryImpl.java:514) at org.hibernate.event.def.DefaultLoadEventListener.onLoad (DefaultLoadEventListener.java:66) at org.hibernate.impl.SessionImpl.fireLoad(SessionImpl.java:862) at org.hibernate.impl.SessionImpl.get(SessionImpl.java:799) at com.aptech.jb.dao.hibimpl.TblUserDAO.findById(TblUserDAO.java:52) at com.aptech.jb.Test.main(Test.java:13),没有在Hibernate.cfg.xml加,回顾,下面代码有哪些错误?,Transaction tx = null; Session session = HibernateSessionFactory.getSession(); try tx = session.beginTransaction();session.open();session.insert(item);session.close(); mit(); catch (Exception e) tx.rollback(); e.printStackTrace();,没有session.open()方法,session.save(item);,应该是session.save(item);,应该先提交事务,再关闭session,关闭session应在finally块中进行,预习检查,1、举一个一对多关联的例子2、举一个多对一关联的例子3、举一个多对多关联的例子4、使用Hibernate配置关联有什么好处?,本章任务,使用Hibernate实现:配置Hibernate关联自动加载区县对应的街道配置Hibernate关联并实现:1、增加一个区县:“山南区”2、增加山南区下属的三个街道3、删除“五四大道”4、划“和平路”到海淀区5、删除山南区配置Hibernate多对多关联,实现某OA系统项目和人员对照关系的管理,本章目标,掌握单向many-to-one关联掌握双向one-to-many关联掌握many-to-many关联,实体间的关联,单向多对一单向一对多,tblJd.getQx().getQxname();,TblJd jd = (TblJd)tblQx.getJds().get(0);jd.getJdname();tblQx.getJds.add(jd);,实体间的关联,双向一对多关系模型,怎样将实体一对多关系映射到数据库?,单向多对一关联,定义“区县” 、“街道”实体如下: 映射文件:,public class Jd private Integer jdid; private String jdname; private Qx qx; / Getters & Setters .,public class Qx private Integer qxid; private String qxname; / Getters & Setters .,多对一关系, , ,只在many一方配置了关联,单向多对一关联,建立测试类,继承自BaseHibernateDAO,public class ManyToOneTest extends BaseHibernateDAO public static void main(String args) new ManyToOneTest().testManyToOne();public void testManyToOne() Jd jd = (Jd)super.get(Jd.class,1);String qxname = jd.getQx().getQxname();System.out.println(qxname + , + jd.getJdname();,通过映射关系的配置即获得了在代码中面向对象编程的便利性!,通过配置many-to-one节点,加载街道(多)信息时,Hibernate自动加载了对应的区县(一)信息,小结,在租房系统中,房屋信息(Fwxx)与用户(User)间也是多对一关系。如何配置映射文件,使之可以通过下面的代码输出房屋信息和发布该信息的用户名称?,Fwxx fwxx = (Fwxx)super.get(Fwxx.class,1);System.out.println( fwxx.getTitle() + , + fwxx.getUser.getUname();,双向一对多关联,现希望通过qx.getJds()即可获得该区县下所有街道的信息。如何配置映射信息?, ,public class Qx private Integer qxid; private String qxname; private Set jds = new HashSet(); / Getters & Setters .,在Qx实体类中,增加jds属性,在Qx映射文件中增加set/one-to-many配置,双向一对多关联,测试程序,Qx qx = (Qx)super.get(Qx.class,1);System.out.println(qx.getQxname();Iterator it = qx.getJds().iterator();while (it.hasNext() Jd jd = (Jd)it.next();System.out.print(jd.getJdname() + );,现在我们在“区县”(一)和“街道”(多)两方面都添加了关联,获得了双向一对多的配置,可以只在一的一方配置,从而得到单向一对多关联,双向一对多关联,在配置好双向一对多后,如何实现下列功能?1、增加一个区县:“山南区”2、增加山南区下属的三个街道:“和平路”、“八一路”和“五四大道”3、删除“五四大道”4、划“和平路”到海淀区5、删除山南区,在one一方添加数据,增加一个区县:山南区,添加成功!,在many一方添加数据,增加山南区下属的三个街道:“和平路”、“八一路”和“五四大道”,在many一方删除数据1,删除“五四大道”,根本没有执行Delete语句,数据没有被删除!,从one一方去“删除”,Hibernate只是执行了update语句。还是未删除成功!,问题出在配置文件上没有配置set节点的inverse属性,inverse是“反转”的意思,表示关联关系的控制权。为true,表示由对方负责关联关系的添加和删除;为false,表示由自己负责维护关联关系。,inverse设为true,由many一方删除,执行了delete语句,删除成功,在many一方删除数据2,在many一方删除数据的正确做法:给配置文件中set属性增加inverse属性,设为false (由many一方负责维护关联) 程序代码:,/ 在对象模型中删除关系Jd jd = (Jd)super.get(Jd.class,366);Qx qx = (Qx)super.get(Qx.class,19);qx.getJds().remove(jd);/ 在数据库中删除数据super.del(Jd.class,366);,/BaseHibernateDAO中del方法代码Transaction tx = null;try tx = session.beginTransaction(); session.delete(this.get(clazz,id); mit(); catch (RuntimeException re) tx.rollback(); throw re; ,只执行super.del即可将数据从数据库中删除但为了保持对象模型和数据库数据一致,还要调用qx.getJds().remove(jd);先从对象模型中删除,修改关联关系,划“和平路”到海淀区,首先对对象模型编码,然后个更新hepinglu(通过inverse属性设定的控制方),执行了update语句,在one一方删除数据,删除山南区删除山南区应级联删除下属的区县,执行了delete语句,但违反外键约束,删除失败,?,如果many一方数据过多,代码繁琐通过配置set节点cascade属性可实现自动级联删除,先删除对应子表数据,删除成功!,在one一方删除数据,set节点之cascade属性all : 对所有操作都进行级联none : 对所有操作都不进行级联save-update : 执行更新操作时级联delete : 执行删除操作时级联代码,自动执行了级联删除,小结,在租房系统中,房屋信息(Fwxx)与用户(User)是多对一关系;房屋信息(Fwxx)与街道(Jd)是多对一关系。请完成下面的方法,完成添加“房屋信息”记录到数据库的功能。,/* * 新建房屋信息记录 * param title 房屋信息标题 * param fwxx 房屋信息内容 * param userId 用户ID * param jdId 街道ID */public void post(String title,String fwxx,int userId,int jdId) /TODO:完成这个方法。,many-to-many关联,Hanni,Tod,胖子,王筝,国家局供应链项目,奴吉亚(中国)Go-Direct销售系统,无敌维护组,某OA系统要解决如下业务问题:1、业务部门为项目式管理2、每个人参与一个或多个项目;每个项目由一个或多个人完成3、系统需要如下功能:a.列出项目的参加人员b.列出某个人参加的所有项目,many-to-many关联,数据库设计project和employee是多对多关系需要建立一个关系表,many-to-many关联,多对多关系怎么映射呢?, . , ,指定关联表的名称,关联表中外键的字段名,使用many-to-many节点配置,关联表中对应外键的字段名,根据业务规则,设置其中一方inverse为true,程序代码,many-to-many关联,编码解决下列问题:1、新招聘了员工:三叔,加入到国家局供应链项目。2、新立项项目:中教集团网银项目,三叔和胖子参加。3、无敌维护组项目结束,Tod和Hanni退出项目组。,many-to-many关联,新招聘了员工:三叔,加入到国家局供应链项目。,新立项项目:中教集团网银项目,三叔和胖子参加。,无敌维

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论