




免费预览已结束,剩余25页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第六章 Hibernate的关联映射 回顾 下面这个异常是怎么回事 该怎么解决 org hibernate MappingException Unknownentity com aptech jb entity TblUseratorg hibernate impl SessionFactoryImpl getEntityPersister SessionFactoryImpl java 514 atorg hibernate event def DefaultLoadEventListener onLoad DefaultLoadEventListener java 66 atorg hibernate impl SessionImpl fireLoad SessionImpl java 862 atorg hibernate impl SessionImpl get SessionImpl java 799 atcom aptech jb dao hibimpl TblUserDAO findById TblUserDAO java 52 atcom aptech jb Test main Test java 13 没有在Hibernate cfg xml加 回顾 下面代码有哪些错误 Transactiontx null Sessionsession HibernateSessionFactory getSession try tx session beginTransaction session open session insert item session close mit catch Exceptione 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 TblJdjd TblJd tblQx getJds get 0 jd getJdname tblQx getJds add jd 实体间的关联 双向一对多关系模型 怎样将实体一对多关系映射到数据库 单向多对一关联 定义 区县 街道 实体如下 映射文件 publicclassJd privateIntegerjdid privateStringjdname privateQxqx Getters Setters publicclassQx privateIntegerqxid privateStringqxname Getters Setters 多对一关系 只在many一方配置了关联 单向多对一关联 建立测试类 继承自BaseHibernateDAO publicclassManyToOneTestextendsBaseHibernateDAO publicstaticvoidmain String args newManyToOneTest testManyToOne publicvoidtestManyToOne Jdjd Jd super get Jd class 1 Stringqxname jd getQx getQxname System out println qxname jd getJdname 通过映射关系的配置即获得了在代码中面向对象编程的便利性 通过配置many to one节点 加载街道 多 信息时 Hibernate自动加载了对应的区县 一 信息 小结 在租房系统中 房屋信息 Fwxx 与用户 User 间也是多对一关系 如何配置映射文件 使之可以通过下面的代码输出房屋信息和发布该信息的用户名称 Fwxxfwxx Fwxx super get Fwxx class 1 System out println fwxx getTitle fwxx getUser getUname 双向一对多关联 现希望通过qx getJds 即可获得该区县下所有街道的信息 如何配置映射信息 publicclassQx privateIntegerqxid privateStringqxname privateSetjds newHashSet Getters Setters 在Qx实体类中 增加jds属性 在Qx映射文件中增加set one to many配置 双向一对多关联 测试程序 Qxqx Qx super get Qx class 1 System out println qx getQxname Iteratorit qx getJds iterator while it hasNext Jdjd 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一方负责维护关联 程序代码 在对象模型中删除关系Jdjd Jd super get Jd class 366 Qxqx Qx super get Qx class 19 qx getJds remove jd 在数据库中删除数据super del Jd class 366 BaseHibernateDAO中del方法代码Transactiontx null try tx session beginTransaction session delete this get clazz id mit catch RuntimeExceptionre tx rollback throwre 只执行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 是多对一关系 请完成下面的方法 完成添加 房屋信息 记录到数据库的功能 新建房屋信息记录 paramtitle房屋信息标题 paramfwxx房屋信息内容 paramuserId用户ID paramjdId街道ID publicvoidpost Stringtitle Stringfwxx intuserId intjdId 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关联 新招聘了员工 三叔 加入到国家局供应链项目 新立项项目 中教集团网银项目 三叔和胖子参加 无敌维护组项目结束 Tod和Hanni
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年智能穿戴行业创新技术应用前景研究报告
- 巴彦淖尔市2025内蒙古巴彦淖尔市直属乌兰牧骑(市歌舞剧院)招聘演职人员10人笔试历年参考题库附带答案详解
- 软件买卖合同书范本6篇
- 商场三包培训课件
- 商品车日常安全培训课件
- 国家事业单位招聘2025中国农科院质标所招聘笔试笔试历年参考题库附带答案详解
- 引水管道项目技术协议书8篇
- 北京市2025北京市体育设施管理中心应届毕业生招聘2人笔试历年参考题库附带答案详解
- 2025陕西秦巴碧水环境检测有限公司招聘(10人)笔试参考题库附带答案详解
- 2025辽宁沈阳盛京资产管理集团有限公司所属子公司沈阳国际陆港集团有限责任公司招聘14人笔试参考题库附带答案详解
- 2025年度反洗钱阶段考试培训试考试题库(含答案)
- 收割芦苇施工方案
- 普通黄金现货购买合同8篇
- 三力测试考试题库及答案视频讲解
- 2025年河南省人民法院聘用书记员考试试题及答案
- 2025年中学教师资格考试《综合素质》核心考点与解析
- 口腔冠延长术
- 部编版七年级语文上册《闻王昌龄左迁龙标遥有此寄》课件
- 诊所经营管理课件
- 江苏亿洲再生资源科技有限公司资源综合利用技改提升项目 环评报告书
- 质量改进培训-课件
评论
0/150
提交评论