文史百科-中国历史

 文史百科-中国历史     |      2019-11-28

 

  1. Hibernate简介

    • Hibernat是一个ORM(关系映射)框架,对JDBC访问数据库的操作进行了简化,并且将数据库表中的字段和关系映射为对象,简化了对数据库的操作。
  2. 使用方法

    • 读取并解析配置文件

    • 读取并解析映射信息,创建SessionFactory

    • 打开Sesssion

    • 创建事务Transation

    • 持久化操作

    • 提交事务

    • 关闭Session

    • 关闭SesstionFactory

  3. 为什么要用Hibernate

    • 对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码。

    • Hibernate是一个基于JDBC的主流持久化框架,是一个优秀的ORM实现。他很大程度的简化DAO层的编码工作

    • hibernate使用Java反射机制,而不是字节码增强程序来实现透明性。

    • hibernate的性能非常好,因为它是个轻量级框架。映射的灵活性很出色。它支持各种关系数据库,从一对一到多对多的各种复杂关系。

  4. 延迟加载

    • 有类的延迟加载和集合的延迟加载,hibernate3添加了属性,查询对象的时候不是立即发出sql语句而是在真正用到对象的时候才发出sql语句

    • lazy=false 管理是否开启懒加载

    • 对象是用load方法,而集合默认为懒加载

  5. session

    • session是维护数据库连接并且执行查询,更新,删除操作,Session不是线程安全的
  6. update和saveOrUpdate的区别

    • update()方法操作的对象必须是持久化了的对象。也就是说,如果此对象在数据库中不存在的话,就不能使用update()方法。

    • saveOrUpdate()方法操作的对象既可以使持久化了的,也可以使没有持久化的对象。如果是持久化了的对象调用saveOrUpdate()则会 更新数据库中的对象;如果是未持久化的对象使用此方法,则save到数据库中。

  7. 一级缓存

    • 一级缓存为session内的缓存 生命周期和session声明周期相同,
  8. 二级缓存

    • 二级缓存是在SessionFactory这个级别维护的缓存,它能够通过节省几番数据库调用往返来提高性能。

    • 放在二级缓存中的数据应该为不经常改变,保密性底的数据

    • Hibernate框架并没有实现二级缓存,是借助于第三方插件来实现的(ehcache)

  9. 查询缓存

    • 查询缓存实际上保存的是sql查询的结果,这样再进行相同的sql查询就可以之间从缓存中拿到结果了。

    • 生命周期: 数据放到查询缓存中,将会一直存在,直到缓存中的数据被更改,则缓存中的数据消失

    • 根据时间戳来判断数据状态

    • 默认关闭,需要配置文件开启,还需要用query.setCacheable(true);来启动

  10. load和get

    • get查询时先查询一级缓存然后二级缓存然后数据数据库,直接返回实体对象,如果查询不到返回null

    • load如果一级缓存查询不到对象会返回一个代理对象,然后等到真正使用这个对象的时候才去查询二级和数据库。查询不到抛异常

  11. hibernate的三种状态之间如何转换

    • 当对象由瞬时状态(Transient)一save()时,就变成了持久化状态;

    • Session 一 Close()了,它的缓存也都关闭了,整个Session也就失效了,这个时候,这个对象变成了游离状态(Detached),但数据库中还是存在的。

    • 当游离状态(Detached)update()时,又变为了持久状态(Persistent)。

    • 当持久状态(Persistent)delete()时,又变为了瞬时状态(Transient), 此时,数据库中没有与之对应的记录。

  12. hibernate里面的sorted collection 和ordered collection有什么区别

    • sorted collection是在内存中通过Java比较器进行排序的

    • ordered collection是在数据库中通过order by进行排序的

  13. persist和save的区别

    • persist不保证立即执行,可能要等到flush;persist不更新缓存;
  14. cascade,即对住对象的更新怎么影响到子对象;

    • save-update: 级联保存(load以后如果子对象发生了更新,也会级联更新). 但它不会级联删除

    • delete: 级联删除, 但不具备级联保存和更新

    • all-delete-orphan: 在解除父子关系时,自动删除不属于父对象的子对象, 也支持级联删除和级联保存更新.

    • all: 级联删除, 级联更新,但解除父子关系时不会自动删除子对象.

    • delete-orphan:删除所有和当前对象解除关联关系的对象

  15. fetch 抓取策略,在配置文件的Set标签配置

    • join : 左外链接 而join方式,主体对象和关联对象用一句外键关联的sql同时查询出来,不会形成多次查询。

    • select : 默认select方式时先查询返回要查询的主体对象(列表),再根据关联外键id,每一个对象发一个select查询,获取关联的对象,形成n+1次查询;

    • subselece : 子查询

  16. 实现关系

    • many-to-one 对象

    • one-to-many set

    • many-to-may Set

  17. POJO的要求

    • 必须有一个无参的构造方法

    • 不能为final

    • 属性要为Private,并且提供get/set

  18. inverse

    • 在多对多关系中默认为flase 表示为两端都在维护关系

    • 应该改为一端维护关系而不是两端。 inverse=true 代表配置这个的一方放弃了维护关系的权利

  19. 数据库中查询速度慢

    • 建索引

    • 减少表之间的关联

    • 优化sql,尽量让sql很快定位数据,不要让sql做全表查询,应该走索引,把数据量大的表排在前面

    • 简化查询字段,没用的字段不要,已经对返回结果的控制,尽量返回少量数据

  20. SessionFactory

    • SessionFactory就是一个用于创建Hibernate的Session对象的工厂。SessionFactory通常是在应用启动时创建好的,应用程序中的代码用它来获得Session对象。作为一个单个的数据存储,它也是线程安全的,所以多个线程可同时使用同一个SessionFactory,hibernate中的配置文件,映射文件,持久化类的信息都保存在SessionFactory。

    • 一个SessionFactory 在启动的时候只能建立一次

  21. 五个核心接口

    • Configuration 接口:配置Hibernate,根据其启动hibernate,创建

    • SessionFactory 接口:初始化Hibernate,充当数据存储源的代理,创建

    • Session 接口:负责保存、更新、删除、加载和查询对象,是线程不安全的,

    • Transaction 接口:管理事务;

    • Query 和Criteria 接口:执行数据库的查询。

  22. Hiberante和Mybatis的区别

    • Hibernate属于全自动ORM映射工具,使用Hibernate查询关联对象或者关联集合对象时,可以根据对象关系模型直接获取,所以它是全自动的。而Mybatis在查询关联对象或关联集合对象时,需要手动编写sql来完成,所以,称之为半自动ORM映射工具。

4、脏读和幻读?

2、n+1问题?

   而hibernate中的Session呢?是用来表示,应用程序和数据库的一次交互(会话)。在这个Session中,包含了一般的持久化方法(CRUD)。而且,Session是一个轻量级对象(线程不安全),通常将每个Session实例和一个数据库事务绑定,也就是每执行一个数据库事务,都应该先创建一个新的Session实例,在使用Session后,还需要关闭Session

              1)fetch="select" 会另外发出一条语句查询集合

下面是3中解决方案:

    SessionFactory接口负责初始化Hibernate。它充当数据存储源的代理,并负责创建Session对象。这里用到了工厂模式。需要注意的是SessionFactory并不是轻量级的,因为一般情况下,一个项目通常只需要一个SessionFactory就够,当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory。----百度百科

              3) 这只 fetch="subselect" 另外发出一条 select 语句抓取前面查询到的所有的实体对象的关联集合 fetch只对 HQL 查询产生影响其他的则不会

一般而言说n+1意思是,无论在一对多还是多对一当查询出n条数据之后,每条数据会关联的查询1次他的关联对象,这就叫做n+1。

   在hibernate中的session并不是http中所说的session,一般把HttpSession对象称为用户会话。。。

 

 

              2) 设置 fetch="join" 采用外连接集合的 lazy 失效

幻读:比如第一个事务对数据库的全部行进行了修改,同时第二个事务插入一条数据到数据库中,这时第一个事务就会发现,数据库中有一条记录没有被修改,像发生了幻觉一样、

3、Hibernate中的get和load加载有什么区别?

相对于load的延迟加载方式,get就直接的多,当我们使用session.get()方法来得到一个对象时,不管我们 使不使用这个对象,此时都会发出sql语句去从数据库中查询出来。

 

    1. 设置@ManyToOne的fetch属性值为fetchType.LAZY,这种方式解决后,后面的n条sql语句按需而发。但是有个弊端,就是如果需要级联查询就无法获取级联对象了。
    2. 设置@BatchSize(size=5)(该注解要加在类上面,跟@Entity在同一位置),这样发出的sql语句减少。这个设置在一定程度上提高了效率。
    3.  join fetch , 如 使用"from Student s left join fetch s.group g", 进行表连接查询,此时就发1条SQL语句。
    4.  使用QBC查询,默认效果与3相同。

当我们使用session.load()方法来加载一个对象时,此时并不会发出sql语句,当前得到的这个对象其实是一个代理对象,这个代理对象只保存了实体对象的id值,只有当我们要使用这个对象,得到其它属性时,这个时候才会发出sql语句,从数据库中去查询我们的对象。

脏读:是指当一个事务正在访问数据,且对数据做了修改,但是还没有提交到数据库。另一个事务查询到这个数据、这个数据就是脏数据,依靠这个数据所做的操作就是不正确的、

1、什么是SessionFactory?什么是Session?httpsession和hibernate的session的有什么区别?