ImageVerifierCode 换一换
格式:DOCX , 页数:12 ,大小:21.50KB ,
资源ID:5383345      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/5383345.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(Hibernate学习笔记.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

Hibernate学习笔记.docx

1、Hibernate学习笔记第一个hibernate项目 1、新建java项目 2、创建User Library用户自定义库,加入如下jar * HIBERNATE_HOME/hibernate3.jar * HIBERNATE_HOME/lib/*.jar * MySql jdbc驱动 3、创建hibernate配置文件hibernate.cfg.xml,为了便于调试最好加入log4j.propertise配置文件 4、定义实体类 5、定义User类的映射文件User.hbm.xml 6、将User.hbml.xml文件加入到hibernate.cfg.xml文件中 7、编写hbm2ddl工具

2、类,将实体类生成数据库表 其中的ExportDB.java是常用类了,写一次就够了. session.SessionFactory8、开发客户端:掌握:Configuration 为了方便跟踪sql执行,在hibernate.cfg.xml文件中加入true 第二个Hibernate_session项目: 测试实体对象的生命周期 junit简介: * 编写测试类xxxTest,需要继承TestCase * 编写单元测试方法,测试方法必须以test开头,测试方法不能含有参数和返回值,如: public void testHello1() * 最好单元测试的代码单独建立一个目录 了解Hiberna

3、te中CRUD操作 了解get和load的区别? * get不支持lazy,load支持lazy * 采用get加载数据,如果没有匹配的数据,返回null,而load则抛出异常 transient状态的特征? * 在数据库中没有与之匹配的数据 * 没有纳入session的管理 persistent状态的特征? * persistent状态的对象在数据库中有与之匹配的数据 * 纳入了session的管理 * 在清理缓存(脏数据检查)的时候,会和数据库同步 detached状态的特征? * 在数据库中有与之匹配的数据 * 没有纳入session的管理 第三个Hibernate_basemappin

4、g项目: hibernate基本映射 实体类-表 实体类中的普通属性-表字段 采用标签映射成数据库表,通过标签将普通属性映射成表字段 所谓普通属性指不包括自定义类、集合和数组等 注意:如果实体类和实体类中的属性和sql中的关键字重复,必须采用table或column重新命名 实体类的设计原则: * 实现一个默认的(即无参数的)构造方法(constructor) * 提供一个标识属性(identifier property)(可选) * 使用非final的类 (可选) * 为持久化字段声明访问器(accessors) 主键生成策略: uuid、native和assigned 第四个多对一关系项目

5、: hibernate多对一关联映射 关联映射的本质: * 将关联关系映射到数据库,所谓的关联关系是对象模型在内存中的一个或多个引用 会在多的一端加入一个外键,指向一的一端,这个外键是由 中的column属性定义的,如果忽略了这个属性那么默认的外键与实体的属性一致 标签的定义示例: 理解级联的含义? 是对象的连锁操作 第五个一对一关系项目: hibernate一对一主键关联映射(单向关联Person-IdCard) 一对一主键关联映射:让两个实体对象的id保持相同,这样可以避免多余的字段被创建 具体映射: idCard 第六个一对一主键双向映射项目: hibernate一对一主键关联映射(双向

6、关联PersonIdCard) 需要在idcard映射文件中加入标签指向person,指示hibernate如何加载person 默认根据主键加载 第七个一对一唯一外键关联项目: hibernate一对一唯一外键关联映射(单向关联Person-IdCard) 一对唯一外键关联映射是多对一关联映射的特例 可以采用标签,指定多的一端的unique=true,这样就限制了多的一端的多重性为一 通过这种手段映射一对一唯一外键关联 第八个一对一唯一外键关联项目: hibernate一对一唯一外键关联映射(双向关联PersonIdCard) 一对一唯一外键关联双向,需要在另一端(idcard),添加标签,

7、指示hibernate如何加载 其关联对象,默认根据主键加载person,外键关联映射中,因为两个实体采用的是person的外键维护的关系, 所以不能指定主键加载person,而要根据person的外键加载,所以采用如下映射方式: 第九个Session_flush项目: session flush测试: session flush方法主要做了两件事: * 清理缓存 * 执行sql session在什么情况下执行flush * 默认在事务提交时 * 显示的调用flush * 在执行查询前,如:iterate hibernate按照save(insert),update、delete顺序提交相关操

8、作 一个完整的Test测试类用Junit工具: 实例. 第十个一对多单向项目: hihernate一对多关联映射(单向Classes-Student) 一对多关联映射利用了多对一关联映射原理 多对一关联映射:在多的一端加入一个外键指向一的一端,它维护的关系是多指向一 一对多关联映射:在多的一端加入一个外键指向一的一端,它维护的关系是一指向多 也就是说一对多和多对一的映射策略是一样的,只是站的角度不同 在一一端维护关系的缺点: * 如果将t_student表里的classesid字段设置为非空,则无法保存 * 因为不是在student这一端维护关系,所以student不知道是哪个班的, 所以需要

9、发出多余的update语句来更新关系 第十一个一对多双向项目: hihernate一对多关联映射(双向ClassesStudent) 一对多双向关联映射: * 在一一端的集合上使用,在对方表中加入一个外键指向一一端 * 在多一端采用 注意:标签指定的外键字段必须和指定的外键字段一致,否则引用字段的错误 如果在”一“一端维护一对多关联关系,hibernate会发出多余的udpate语句,所以我们一般在多 的一端来维护关联关系 关于inverse属性: inverse主要用在一对多和多对多双向关联上,inverse可以被设置到集合标签上, 默认inverse为false,所以我们可以从”一“一端和

10、”多“一端维护关联关系, 如果设置成inverse为true,则我们只能从多一端来维护关联关系 注意:inverse属性,只影响数据的存储,也就是持久化 inverse和cascade * inverse是关联关系的控制方向 * cascade操作上的连锁反应 第十二个多对多单向映射项目: hibernate多对多关联映射(单向User-Role) 具体映射方式: 第十三个多对多映射项目: hibernate多对多关联映射(双向UserRole) 映射方法: table属性值必须和单向关联中的table属性值一致 中column属性值要与单向关联中的标签中的column属性值一致 在中的col

11、umn属性值要与单向关联中标签的column属性值一致 第十四个Lazy策略项目: hibernate lazy策略可以使用在: * 标签上,可以取值:true/false * 标签上,可以取值:true/false需要类增强工具 * 标签上,可以取值:true/false/extra * 单端关联上,可以取值:false/proxy/noproxy lazy概念:只有真正使用该对象时,才会创建,对于hibernate而言,正真使用的时候才会发出sql hibernate支持lazy策略只有在session打开状态下有效 标签上的lazy特性只对普通属性起作用 hibernate在集合上的la

12、zy策略,可以取值:true/false/extra 标签上的lazy不会影响到集合上的lazy特性 hibernate在单端关联上的lazy策略,可以取值:false/proxy/noproxy 标签上的lazy不会影响到单端关联上的lazy特性 第十七个项目: 每棵继承树映射成一张表 1、理解如何映射 因为类继承树肯定是对应多个类,要把多个类的信息存放在一张表中,必须有某种机制来区分哪些记录是属于哪个类的。 这种机制就是,在表中添加一个字段,用这个字段的值来进行区分。用hibernate实现这种策略的时候,有如下步骤: 父类用普通的标签定义 在父类中定义一个discriminator,即指

13、定这个区分的字段的名称和类型 如: 子类使用标签定义,在定义subclass的时候,需要注意如下几点: Subclass标签的name属性是子类的全路径名 在Subclass标签中,用discriminator-value属性来标明本子类的discriminator字段(用来区分不同类的字段) 的值Subclass标签,既可以被class标签所包含(这种包含关系正是表明了类之间的继承关系),也可以与class标 签平行。 当subclass标签的定义与class标签平行的时候,需要在subclass标签中,添加extends属性,里面的值 是父类的全路径名称。子类的其它属性,像普通类一样,定义

14、在subclass标签的内部。 2、理解如何存储 存储的时候hibernate会自动将鉴别字段值插入到数据库中,在加载数据的时候,hibernate能根据这个鉴别值 正确的加载对象 多态查询:在hibernate加载数据的时候能鉴别出正真的类型(instanceOf) get支持多态查询 load只有在lazy=false,才支持多态查询 hql支持多态查询 第十八个项目:每个子类映射成一张表: 每个子类映射成一张表 1、理解如何映射 这种策略是使用joined-subclass标签来定义子类的。父类、子类,每个类都对应一张数据库表。 在父类对应的数据库表中,实际上会存储所有的记录,包括父类和

15、子类的记录;在子类对应的数据库表中, 这个表只定义了子类中所特有的属性映射的字段。子类与父类,通过相同的主键值来关联。实现这种策略的时候, 有如下步骤: 父类用普通的标签定义即可 父类不再需要定义discriminator字段 子类用标签定义,在定义joined-subclass的时候,需要注意如下几点: Joined-subclass标签的name属性是子类的全路径名 Joined-subclass标签需要包含一个key标签,这个标签指定了子类和父类之间是通过哪个字段来关联的。 如:,这里的column,实际上就是父类的主键对应的映射字段名称。 Joined-subclass标签,既可以被c

16、lass标签所包含(这种包含关系正是表明了类之间的继承关系), 也可以与class标签平行。 当Joined-subclass标签的定义与class标签平行的时候,需要在Joined-subclass 标签中,添加extends属性,里面的值是父类的全路径名称。子类的其它属性,像普通类一样,定义在joined-subclass标签的内部。 第十九个项目:每个具体类映射成一张表: 1、理解如何映射 这种策略是使用union-subclass标签来定义子类的。每个子类对应一张表,而且这个表的信息是完备的, 即包含了所有从父类继承下来的属性映射的字段(这就是它跟joined-subclass的不同之

17、处, joined-subclass定义的子类的表,只包含子类特有属性映射的字段)。实现这种策略的时候,有如下步骤: 父类用普通标签定义即可 子类用标签定义,在定义union-subclass的时候,需要注意如下几点: Union-subclass标签不再需要包含key标签(与joined-subclass不同) Union-subclass标签,既可以被class标签所包含(这种包含关系正是表明了类之间的继承关系), 也可以与class标签平行。 当Union-subclass标签的定义与class标签平行的时候,需要在Union-subclass 标签中,添加extends属性,里面的值是

18、父类的全路径名称。子类的其它属性,像普通类一样, 定义在Union-subclass标签的内部。这个时候,虽然在union-subclass里面定义的只有子类的属性, 但是因为它继承了父类,所以,不需要定义其它的属性,在映射到数据库表的时候,依然包含了父类的所 有属性的映射字段。 注意:在保存对象的时候id是不能重复的(不能使用自增生成主键) 第二十个项目:Component映射: component映射 在hibernate中,component是某个实体的逻辑组成部分,它与实体的根本区别是没有oid, component可以成为是值对象(DDD) 采用component映射的好处:它实现了

19、对象模型的细粒度划分,层次会更分明,复用率会更高 第二十一个项目: 复合(联合)主键映射 通常将复合主键相关的属性,单独放到一个类中 * 此类必须实现序列化接口 * 覆写hashcode和equals方法 set list array map 悲观锁 悲观锁的实现,通常依赖于数据库机制,在整个过程中将数据锁定,其它任何用户都不能读取或修改 乐观锁 大多数基于数据版本记录机制( 一般是在数据库表中加入一个version字段 读取数据时将版本号一同读出,之后更新数据时版本号加一,如果提交数据时版本号小于或等于数据表中 的版本号,则认为数据是过期的,否则给予更新,抛出异常: StaleObjectS

20、tateException 第二十二个项目:HQL语句查询: hibernate查询语言hql 在hql中关键字不区分大小写,但是属性和类名区分大小写 1、简单属性查询【重要】 * 单一属性查询,返回结果集属性列表,元素类型和实体类中相应的属性类型一致 * 多个属性查询,返回的集合元素是对象数组,数组元素的类型和对应的属性在实体类中的类型一致 数组的长度取决与select中属性的个数 * 如果认为返回数组不够对象化,可以采用hql动态实例化Student对象 参见:SimplePropertyQueryTest.java 2、实体对象查询【重要】 * N + 1问题,在默认情况下,使用quer

21、y.iterate查询,有可以能出现N+1问题 所谓的N+1是在查询的时候发出了N+1条sql语句 1: 首先发出一条查询对象id列表的sql N: 根据id列表到缓存中查询,如果缓存中不存在与之匹配的数据,那么会根据id发出相应的sql语句 * list和iterate的区别? * list每次都会发出sql语句,list会向缓存中放入数据,而不利用缓存中的数据 * iterate:在默认情况下iterate利用缓存数据,但如果缓存中不存在数据有可以能出现N+1问题 参见:SimpleObjectQueryTest1.java/SimpleObjectQueryTest2.java 3、条件

22、查询【重要】 * 可以采用拼字符串的方式传递参数 * 可以采用 ?来传递参数(索引从0开始) * 可以采用 :参数名 来传递参数 * 如果传递多个参数,可以采用setParamterList方法 * 在hql中可以使用数据库的函数,如:date_format 参见:SimpleConditionQueryTest.java 4、hibernate也支持直接使用sql进行查询 参见:SqlQueryTest.java 5、外置命名查询 * 在映射文件中采用标签来定义hql * 在程序中采用session.getNamedQuery()方法得到hql查询串 参见:Student.hbm.xml、N

23、ameQueryTest.java 6、查询过滤器 * 在映射文件中定义过滤器参数 * 在类的映射中使用这些参数 * 在程序中启用过滤器 参见:Student.hbm.xml、FilterQueryTest.java 7、分页查询【重要】 * setFirstResult(),从0开始 * setMaxResults,每页显示多少条数据 参见:PageQueryTest.java 8、对象导航查询,在hql中采用 . 进行导航【重要】 参见:ObjectNavQueryTest.java 9、连接查询【重要】 * 内连 * 外连接(左连接/右连接) 参见:JoinQueryTest.java 10、统计查询【重要】 参见:StatQueryTest.java 11、DML风格的操作(尽量少用,因为和缓存不同步) 参见:DMLQueryTest.java 第二十三个项目:缓存介绍及掌握 0. 一级缓存是缓存实体对象的,而不是缓存普通属性的. 1. 一级缓存与session同时存在与消亡的. 2. 3.

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1