多对多的实体映射实现.ppt

上传人:得****1 文档编号:76365292 上传时间:2023-03-09 格式:PPT 页数:22 大小:472.54KB
返回 下载 相关 举报
多对多的实体映射实现.ppt_第1页
第1页 / 共22页
多对多的实体映射实现.ppt_第2页
第2页 / 共22页
点击查看更多>>
资源描述

《多对多的实体映射实现.ppt》由会员分享,可在线阅读,更多相关《多对多的实体映射实现.ppt(22页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、多对多的实体映射实现多对多的实体映射实现在本讲您能了解如下知识点在本讲您能了解如下知识点q创建创建HibernateHibernate的配置文件。的配置文件。q创建持久化类。创建持久化类。q创建对象创建对象-关系映射文件。关系映射文件。q编程基于编程基于HibernateHibernate的的DAODAO组件组件q实现实现“多对多多对多”的关联映射的关联映射1 1、多对多关联的实现方案、多对多关联的实现方案(1 1)类似一对多情形中的最常用方案,为关联的双方增加)类似一对多情形中的最常用方案,为关联的双方增加到对方的外键到对方的外键 操作比较简单,缺点是会造成数据冗余;操作比较简单,缺点是会造

2、成数据冗余;一、实现一、实现“多对多多对多”的关联映射的原理的关联映射的原理(2 2)新增一张包含关联双方主键的关联表)新增一张包含关联双方主键的关联表 在取数据时,需要链接该关联表和数据表,优点是没有在取数据时,需要链接该关联表和数据表,优点是没有数据冗余,缺点是带来了一定的时限复杂度。数据冗余,缺点是带来了一定的时限复杂度。2 2、注意的问题、注意的问题(1 1)“多对多多对多”由于使用了中间数据库表,在查询效率方面比由于使用了中间数据库表,在查询效率方面比较低较低(2 2)并且在对象模式上,)并且在对象模式上,“多对多多对多”会使得对象与对象之间彼会使得对象与对象之间彼此依赖,因此该种设

3、计并不是一个良好的设计方式此依赖,因此该种设计并不是一个良好的设计方式(3 3)我们在系统的数据访问层的设计上应尽可能避免使用)我们在系统的数据访问层的设计上应尽可能避免使用“多多对多对多”关系。关系。3 3、多对多的关联也同样可以采用、多对多的关联也同样可以采用SetSet、ListList等多种方式的等多种方式的属性标签属性标签4 4、基于中间连接表的多对多关联的映射文件的示例、基于中间连接表的多对多关联的映射文件的示例 注意注意标签的定义标签的定义 中间连接表中间连接表1 1、设计本示例中所需要的数据库、设计本示例中所需要的数据库2 2、利用、利用HibernateHibernate连接

4、数据库连接数据库(1 1)方式一:采用直接连接)方式一:采用直接连接(2 2)方式二:采用基于容器的)方式二:采用基于容器的JNDIJNDI数据源数据源 本例采用本例采用TomcatTomcat中所提供的中所提供的JNDIJNDI的数据库连接池的数据库连接池二、在二、在WebWeb应用中实现数据库访问应用中实现数据库访问4 4、将、将HibernateHibernate的的库文件放到库文件放到WebWeb应用的应用的/WEB-/WEB-INF/libINF/lib目录目录中中3 3、在、在TomcatTomcat的的server.xmlserver.xml文件进行配文件进行配置置5 5、配置、

5、配置HibernateHibernate系统系统 本例的本例的XMLXML格式的格式的HibernateHibernate配置文件配置文件hibernate.cfg.xmlhibernate.cfg.xml文文件的内容如下件的内容如下6 6、配置、配置log4j.propertieslog4j.properties属性文件属性文件7 7、在、在WebWeb应用所在的目录中添加应用所在的目录中添加数据库的数据库的JDBCJDBC驱动程序的各个驱动程序的各个*.jar*.jar包文件包文件8 8、编写、编写POJOPOJO类及其要求类及其要求(1 1)POJOPOJOp简单传统简单传统JavaJa

6、va对象(对象(POJO-Plain Old Java ObjectPOJO-Plain Old Java Object,有,有时候也称作时候也称作Plain Ordinary Java ObjectsPlain Ordinary Java Objects)编程模型)编程模型pHibernateHibernate使用简单的使用简单的JavaJava对象来进行持久化。对象来进行持久化。(2 2)POJOPOJO类代码的风格要求类代码的风格要求p一个一个POJOPOJO很类似于很类似于JavaBeanJavaBean的代码风格的代码风格p并且它应该有一个没有参数的构造函数并且它应该有一个没有参数的

7、构造函数(3 3)实体类中的标识属性)实体类中的标识属性 idp实体类中的实体类中的id id 属性(属性(propertyproperty)为一个实体类的实例提供为一个实体类的实例提供标识属性(标识属性(identifier propertyidentifier property)的值)的值p它是一个特殊的属性,代表了这个类的数据库标识符(主键)它是一个特殊的属性,代表了这个类的数据库标识符(主键)(4 4)本例中的实体类代码)本例中的实体类代码(5 5)实体类中的)实体类中的equalsequals方法方法如如果果我我们们有有如如下下需需求求,则则必必须须重重载载 equalsequals

8、()()方法:方法:p想想把把持持久久类类的的实实例例放放入入SetSet中中(当当表示多值关联时,推荐这么做)表示多值关联时,推荐这么做)p想重用脱管实例想重用脱管实例 p实实现现equals()equals()最最显显而而易易见见的的方方法法是是比比较较两两个个对对象象标标识识符符的的值值。如如果果值值相相同同,则则两两个个对对象象对对应应于于数数据据库库的的同同一一行行,因因此此它它们们是是相相等等的的(如如果果都都被被添添加加到到 SetSet,则则在在SetSet中中只只有一个元素)。有一个元素)。9 9、映射前面所设计的、映射前面所设计的BookBook数据库表数据库表(1 1)映

9、射文件的作用)映射文件的作用pHibernateHibernate需要知道怎样去加载(需要知道怎样去加载(loadload)和存储()和存储(storestore)我们的持久化类的对象。这里正是我们的持久化类的对象。这里正是HibernateHibernate映射文件映射文件(mapping filemapping file)发挥作用的地方)发挥作用的地方p映射文件告诉映射文件告诉HibernateHibernate它应该访问数据库里面的哪个表它应该访问数据库里面的哪个表(tabletable)和应该使用表里面的哪些字段()和应该使用表里面的哪些字段(columncolumn)。)。(2 2)

10、命名规则:类名)命名规则:类名.hbm.xml.hbm.xml(3 3)本示例中的)本示例中的Book.hbm.xmlBook.hbm.xml映射文件的内容映射文件的内容 1010、编程基于、编程基于HibernateHibernate的的DAODAO组组件以进行数据的访件以进行数据的访问操作问操作1111、在某个、在某个WebWeb应应用中使用上面的用中使用上面的程序程序1212、执行该、执行该WebWeb应用应用(1 1)将在浏览器中看到下面的执行结果)将在浏览器中看到下面的执行结果(2 2)同时,在数据库表中将出现下面的记录)同时,在数据库表中将出现下面的记录三、实现本例中的三、实现本例

11、中的“多对多多对多”实体之间的关联实体之间的关联1 1、在、在MS SQLServerMS SQLServer的本例的数据库中增加一个数据库表的本例的数据库中增加一个数据库表BookAuthorBookAuthor2 2、决定、决定BookAuthorBookAuthor和和BookBook之间的关系之间的关系3 3、新增一个、新增一个BookAuthorBookAuthor类类 并且在并且在BookAuthorBookAuthor类增加一组类增加一组BookBook,这样我们可以轻松的,这样我们可以轻松的通过调用通过调用aPerson.getBooks()aPerson.getBooks()

12、得到一个得到一个BookAuthorBookAuthor所拥有的所拥有的BookBook列表,而不必执行一个显式的查询(一个单向的列表,而不必执行一个显式的查询(一个单向的Set-basedSet-based关联)。关联)。4 4、为该实体类创建一个、为该实体类创建一个BookAuthor.hbm.xmlBookAuthor.hbm.xml映射文件映射文件 6 6、在、在HibernateDAOBean.javaHibernateDAOBean.java中增加一个产生关联数据的中增加一个产生关联数据的方法方法5 5、在、在hibernate.cfg.xmlhibernate.cfg.xml配置

13、文件中增加对配置文件中增加对该文件的定义该文件的定义7 7、在、在WebWeb应用的组件中添加下面的代码应用的组件中添加下面的代码 8 8、执行该组件、执行该组件9 9、在、在HibernateDAOBean.javaHibernateDAOBean.java中增加一个获得关联数据的中增加一个获得关联数据的方法方法1010、在、在WebWeb应应用的组件中添用的组件中添加下面的代码加下面的代码 1111、执行该、执行该WebWeb应用应用1212、在控制台上将出现下面的状态提示内容、在控制台上将出现下面的状态提示内容本讲内容。本讲内容。孔子说:孔子说:“学而不思则罔,思而不学则殆。学而不思则罔,思而不学则殆。”

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 应用文书 > 工作报告

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁