Hibernate学习笔记(一)

Hibernate学习笔记(一):

1.对象状态与数据库中的记录有关联:指与数据库中的id有关系

2.创建Hibernate项目的过程

(1)导包(各个包的含义)

(2)添加到类的构建路径下

(3)hibernate.cfg.xml主配置文件的配置

(4)创建数据库

(5)配置domain的类和配置文件

(6)导入HibernateUtils的工具包

(7)测试

3.三种状态的转换

(1)持久状态:save()方法会使用主键生成策略,为User指定id

主键自增则打印insert语句

hibernate自增则打印select语句(查找最大的id)

assigned的时候则报错,需要先手动设置主键

(2)瞬时状态=》游离状态(都与数据库没有关联,但是游离状态有id)

猜想:callback或者设置了id

结果:设置了数据库已有的id但是不提交,不与session关联

(3)持久状态=》游离状态

session.evict():在没有关闭session的状态下可以移除user和session的关联

(4)三态的作用:持久状态,我们使用Hibernate主要是为了持久化我们的数据.
// 对于对象的状态,我们期望我们需要同步到数据库的数据,都被装换成持久状态
//持久化状态特点: Hibernate会自动将持久化状态对象的变化同步到数据库中

(5)与session建立关联的对象的ID不允许修改

4.缓存:

(1)一级session缓存:线程缓存

(2)二级hibernate缓存:进程缓存

5.一级缓存以Map<串行化,Object>形式存在

  1. 序列化是将对象状态转换为可保持或传输的格式的过程。说明白点就是你可以用对象输出流输出到文件.如果不序列化输出的话.很可能会乱!

7.快照存在于session中,当从数据库查询回来时,会生成一式两份的数据,一个为缓存,一个为快照,将缓存返回,提交session时与快照进行比较;

8.提交更新时,如果有关ID,则会存在缓存中,但是快照必须与数据库有关才会存在。

9.HQL语句不会使用一级缓存,但是HQL的查询结果会进入缓存

10.原生SQL语句返回的数据如果不封装成对象就不会使用缓存

11.criteria返回的数据本来就是面向对象的,所以会使用缓存

12.save()和persist()的区别:

(1)save():如果保存的对象在保存之前设置了ID.那么该ID也被认为是无效的ID

(2)persist():在保存之前设置了ID.那么就会将设置的ID进行insert. 但是 主键策略是由数据库来维护. 所以产生矛盾.所以抛出异常.

解决方法:设置主键生成策略:自己指定

13.当数据库的数据和缓存的数据不一致时,使用JDBC

14.evict():移除缓存中的对象

clear():清空一级缓存

refresh():强制刷新缓存中的对象 => (可以用来解决缓存与数据库数据不同步的问题)

flush():对比快照,并提交缓存对象,数据有修改,立刻提交session缓存中的对象到数据库

15.saveOrUpdate()可以同时完成保存或更新操作(代理主键=> native)

主键为空=>save

主键有值=>update

16.inverse:true:是否放弃对外键的维护

17.关系型hibernate在设置级联时千万不要在两方都配置级联删除,删除任何一方,会导致整个关系链对象全部删除

18.all-delete-orphan:三种级联组合

19.加载策略

(1)延迟加载:等到使用的时候才会加载

(2)立即加载:立刻加载

20.(1)类级别加载策略

load:与class的lazy属性配合使用,若是true(默认),先返回一个代理对象,当使用代理对象的属性时才去查询数据库,若是false,会和get一致,立刻去加载数据库

(2)关联级别加载策略

在查询有关联关系的数据时,加载一方的数据是否需要将另一方立即查出,默认:与我相关的数据,在使用时才会加载

extra:极其懒惰,如果使用集合时,只调用size()方法查询数量,只会用select count语句,不会查询里面数据

21.set:

lazy

fetch:sql语句的类型

(1)select(默认值):普通查询语句

(2)join:连接查询集合数据

(3)subselect:使用子查询加载集合数据,一次加载多个Customer
的订单数据

22.lazy和fetch的组合

fetch      lazy      结论

select     true      在集合使用的时候才会加载

select     false     立刻使用加载

select     extra     与true相同,但是在查询长度时,会只发送count语句

join       true(失效)表连接查询,立刻加载

join       false     表连接查询,立刻加载

join       extra     立刻查询

subselect  true      在集合查询时,使用子查询 

subselect  false     立刻使用子查询语句查询

subselect  extra     立刻使用子查询语句查询,获取集合长度时会发送count语句

总结:

以上为学习Hibernate时所作的部分笔记,如果有错欢迎指出。

猜你喜欢

转载自blog.csdn.net/zpr5554321/article/details/81161172
今日推荐