实验三Hibernate映射2附加多对多.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验三Hibernate映射2附加多对多

Hibernate 映射(多对多双向关联) 1. 内容回顾 1) Hibernate 映射的基本概念 2) Hibernate 映射有关的配置文件 3) Hibernate 映射的类别 2. 实验目的 1) 掌握hibernate 映射配置文件的编写 2) 掌握hibernate 常用映射的应用 3) 理解hibernate 映射的原理 3. 实验指导 3.1 按照实验一搭建hibernate 应用开发环境。 3.2 开发hibernate 多对多映射应用,实现对部门,员工,工作的基本 操作,理解他们之间的关系: 3.2.1 多对多双向关联实例 1)在 MySQL 数据库服务器中,创建一个名为hibrole 的数据库并 切换为当前数据库,其语句如下: create database hibrole default character set utf8; use hibrole; 2 )在hibrole 数据库中,创建roles, privilege 和rolepriv 表,语句 如下: (下面代码插入测试记录) 其中rolepriv 表达roles 与privilege 之间的多对多关系. 3 )右击工程名称,选择 buildpath/config build path/library/ add external jars,并添加MySQL 数据库驱动程序的jar 包. 4) 在工程的 SRC 目录下创建一个名称为 hibernate.cfg.xml (Hibernate 的核心配置文件)的文件,其内容如下:(部分信息) 5) 在工程的SRC 目录下创建如下图所示的包和类: 其中类及文件的内容分别如下: Role.java 表示一个角色类, 代码如下: Role.hbm.xmlRole 类的映射配置文件,代码如下(部分代码) : Privilege.java 表示一个权限类, 代码如下: Privilege.hbm.xml Privilege 类的映射配置文件,部分代码如下 其中:lazy=true 表示在加载 privilege 对象时,延迟加载与其对应 的所有的role 对象。Inverse=true 表示role 与privilege 之间的关系 有对方去维护。 HibernateSessionFactory.java 是Hibernate 的Session 工厂辅助类, 代码如下:(与实验一相同) MyManager.java 是该应用的一个测试类,代码如下: 6 )分别用下面的代码替换上面的“此处添加代码”处,并回答相 应问题: A . 执行下面代码: 查看Console,有几条查询语句?查询的是那个表? 在上面的代码下面再加上下面代码,重新运行测试: 再查看Console,有几条查询语句?查询的是那个表? 与上面的输出是否相同,为什么? B. 执行下面代码: 查看Console,有几条查询语句?查询的是那个表? 在上面的代码下面再加上下面代码,重新运行测试: 再查看Console,有几条查询语句?查询的是那个表? 与上面的输出是否相同,为什么? C . 执行下面代码: 查看 Console,有几条语句?,分别是什么语句? 并查询数据库 中的roles,privilege 和rolepriv 表看看发生什么变化? D.在 C 中的代码中,在 session.save(p)前面加上下面语句,并允 许测试: 查看Console,有几条语句?,分别是什么语句? 并查询数据库中 的roles,privilege 和rolepriv 表看看发生什么变化? 与C 中的结果有什么不同,为什么? E.在C 中的代码中,用 替换原 来的语句: 并将session.save(p)修改 为session.save(r),然后运行测试: 查看Console,有几条语句?,分别是什么语句? 并查询数据库中的 roles,

文档评论(0)

liangyuehong + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档