对象关系映射-Hibernate

上传人:xian****812 文档编号:324059271 上传时间:2022-07-12 格式:PPT 页数:53 大小:303.50KB
返回 下载 相关 举报
对象关系映射-Hibernate_第1页
第1页 / 共53页
对象关系映射-Hibernate_第2页
第2页 / 共53页
对象关系映射-Hibernate_第3页
第3页 / 共53页
对象关系映射-Hibernate_第4页
第4页 / 共53页
对象关系映射-Hibernate_第5页
第5页 / 共53页
点击查看更多>>
资源描述

《对象关系映射-Hibernate》由会员分享,可在线阅读,更多相关《对象关系映射-Hibernate(53页珍藏版)》请在金锄头文库上搜索。

1、对象对象/关系映射关系映射Hibernate作者:钱安川(Moxie)q学员要求学员要求:熟悉Java、SQL、JDBC,掌握面向对象的开发方法,并有实际项目开发经验q课程目标:课程目标:理解O/RMapping原理,掌握Hibernate开发的相关知识,并能使用Hibernate进行实际项目开发目录目录一、持久化层O/RMapping二、Hibernate入门三、Hibernate映射申明(Mappingdeclaration)四、持久化对象的状态和生命周期五、Hibernate查询六、Hibernate最佳实践一、持久化层一、持久化层O/R Mapping基于B/S的典型三层架构如何分层?

2、如何分层?q业务逻辑层和持久化层绝不要依赖于展现层。q使用假设法测试。例子:1、一个显示课程考试分数的列表。现在要将不及格的分数用红色字体显示(低于60分)。2、搜索。如何进行对象关系数据库的匹配如何进行对象关系数据库的匹配public class User private String name;private String password;private List address;create table tbl_user(name varchar(255)not null,password varchar(255),.primary key(name)如何进行对象如何进行对象关系数据库

3、的匹配关系数据库的匹配?对象对象关系数据库关系数据库类的属性(基本类型)表的列类表1:n/n:1外键n:m关联表继承单表继承、具体表继承、类表继承对象对象关系数据库的不匹配范式关系数据库的不匹配范式q粒度(granularity)的问题q子类型(subtypes)的问题q同一性(identity)的问题q与关联(associations)有关的问题q对象结构导航(navigation)的问题范式不匹配的代价范式不匹配的代价q花费很多时间和精力来手工实现对象和关系的匹配。q甚至要扭曲对象模型直到它与下层的关系技术匹配为止。qJDBCAPI本身的问题。JDBC和SQL提供了一个面向语句(即命令)的

4、方法从SQL数据库中来回移动数据。至少在三个时刻(Insert,Update,Select)必须指定一个结构化关系,这增加了设计和实现所需要的时间。基于关系数据库的持久层可选方案基于关系数据库的持久层可选方案优点优点缺点缺点SQL/JDBC成熟,流行,使用DAO模式代码烦杂,可读性差,维护困难,移植困难Entity BeanCMP(EJB1.1之后),未来的EJB3错误的设计。不可移植,依赖性强,不可序列化,不支持多态的关联查询JDO简单、透明、标准不够成熟基于关系数据库的持久层可选方案基于关系数据库的持久层可选方案优点优点缺点缺点Apache OJB性能、稳定性,属于Apache基金组织文档

5、资源太少,支持标准太多成了负担(ODMG3.0,JDO1.0)iBATIS可以控制更多的数据库操作细节。实用于遗留系统的改造和对既有数据库的复用。持久层封装不够彻底,只是一个DBHelper。Hibernate成熟、流行、功能强大。并逐渐发展成Java持久层事实上的标准。不够透明O/RMapping-What?Why?什么是什么是O/R Mapping?对象-关系映射是一门非常实用的工程技术,它实现了Java应用中的对象到关系数据库中的表的自动的(和透明的)持久化,使用元数据(metadata)描述对象与数据库间的映射。O/R Mapping的优点的优点q提高生产率(Productivity)

6、q可维护性(Maintainability)q更好性能(Performance)q厂商独立性(Vendorindependence)二、二、Hibernate入门入门Hibernate概述概述Hibernate是非常优秀、成熟的O/RMapping框架。它提供了强大的对象和关系数据库映射以及查询功能。Hibernate优势优势q开源(LGPL)q成熟q流行(约13000downloads/month)q自定义APIqJBoss将用Hibernate3实现EntityBeansHibernate开发步骤开发步骤一、持久化类的设计一、持久化类的设计二、持久化类和关系数据库二、持久化类和关系数据库的

7、映射的映射三、应用的开发三、应用的开发持久化持久化Java类必须遵循的原则类必须遵循的原则q为类的持久化类字段申明访问方法(get/set)。Hibernate对JavaBeans风格的属性实行持久化。q实现一个默认的构造方法(constructor)。这样的话Hibernate就可以使用Constructor.newInstance()来实例化它们。q如果是集合类型的属性,它的类型必须定义为集合的接口。例如:List、Set。q提供一个标识属性(identifierproperty)。如果没有该属性,一些功能不起作用,比如:级联更新(Cascadedupdates)Session.saveO

8、rUpdate()。持久化类和关系数据库的映射持久化类和关系数据库的映射XDoclet:它通过在Java源代码中加入特定的JavaDoctag,从而为其添加特定的附加语义,之后通过XDoclet工具对代码中JavaDocTag进行分析,自动生成与代码对应的配置文件(http:/)。XDoclet提供了对Hibernate的支持,这样我们可以直接由Java代码生成Hibernate映射文件。Middlegen:从数据库中已有的表结构中生成Hibernate映射文件。当前版本是2.1可以去http:/boss.bekk.no/boss/middlegen下载。Hibernate核心接口核心接口Co

9、nfiguration概述:概述:Configuration类负责管理Hibernate的配置信息。它包括如下内容:qHibernate运行的底层信息:数据库的URL、用户名、密码、JDBC驱动类,数据库Dialect,数据库连接池等。qHibernate映射文件(*.hbm.xml)。Hibernate配置的两种方法:配置的两种方法:q属性文件(hibernate.properties)。调用代码:Configurationcfg=newConfiguration();qXml文件()。调用代码:Configurationcfg=newConfiguration().configure();

10、Configuration例子数据库连接的配置数据库连接的配置hibernate.dialect hibernate.connection.driver_class jdbc:mysql:/localhost/hibernatehibernate.connection.username root数据库连接池的配置数据库连接池的配置DBCP(App Server连接池首选)连接池首选)hibernate.connection.provider_class 配置配置DBCP连接池连接池其它hibernate.show_sql true 50 25SessionFactory概述:概述:应用程序从S

11、essionFactory(会话工厂)里获得Session(会话)实例。它在多个应用线程间进行共享。通常情况下,整个应用只有唯一的一个会话工厂例如在应用初始化时被创建。然而,如果你使用Hibernate访问多个数据库,你需要对每一个数据库使用一个会话工厂。会话工厂缓存了生成的SQL语句和Hibernate在运行时使用的映射元数据。调用代码:调用代码:SessionFactory sessionFactory=cfg.buildSessionFactory();Session(会话会话)概述:概述:qSession不是线程安全的,它代表与数据库之间的一次操作,它的概念介于Connection和T

12、ransaction之间。qSession也称为持久化管理器,因为它是与持久化有关的操作接口。qSession通过SessionFactory打开,在所有的工作完成后,需要关闭。q它与Web层的HttpSession没有任何关系。调用代码调用代码Sessionsession=sessionFactory.openSession();Transaction(事务事务)概述:概述:它将应用代码从底层的事务实现中抽象出来这可能是一个JDBC事务,一个JTA用户事务或者甚至是一个公共对象请求代理结构(CORBA)允许应用通过一组一致的API控制事务边界。这有助于保持Hibernate应用在不同类型的执

13、行环境或容器中的可移植性。调用代码:调用代码:Transactiontx=session.beginTransaction();v注:注:使用Hibernate进行操作时(增、删、改)必须显示的调用Transaction(默认:autoCommit=false)。Query概述:概述:Query(查询)接口允许你在数据库上执行查询并控制查询如何执行。查询语句使用HQL或者本地数据库的SQL方言编写。调用代码:调用代码:Queryquery=session.createQuery(“fromUser”);用户的例子用户的例子持久化类持久化类User.javapublicclassUserpriv

14、ateLongid;privateStringname;privateDatebirthday;privateStringemail;publicUser()publicUser(Stringname,Datebirthday,Stringemail).Get/Set映射文件映射文件User.hbm.xml应用应用UserTest.javapublicvoidtestCreate()throwsExceptionConfigurationcfg=newConfiguration(););SessionFactorysessionFactory=cfg.buildSessionFactory()

15、;Sessionsession=sessionFactory.openSession();Transactiontx=session.beginTransaction();SimpleDateFormatformat=newSimpleDateFormat(yyyy-mm-dd);Useruser=newUser(Jack,format.parse(1980-04-12),J);session.save(user);mit();assertNotNull(user.getId();session.clear();Useruser_2=(User)session.get(User.class,u

16、ser.getId();assertNotNull(user_2);session.close();应用应用UserTest.java保存用户:session.save(user);修改用户:session.update(user);保存或修改用户:session.saveOrUpdate(user);删除用户:session.delete(user);删除所有用户:session.delete(“fromUser”);查询用户名为“test”的用户:Queryquery=session.createQuery(fromUserwhereuser.name=:name);query.setParameter(“test,user.getName();UserfindUser=(User)query.list().get(0);三、三、Hibernate映射申明映射申明(Mapping declaration)hibernate-mapping一、类层次。class1、主键。id2、基本类型。property3、自定义类。many-to-one|one-to-one4、集合。set|li

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

当前位置:首页 > 中学教育 > 教学课件 > 高中课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号