java

导航

Java面试题分享-Hibernate

来源 :中华考试网 2020-11-07

  问:hibernate六大接口

  答:1)Configuration接口:负责配置并启动Hibernate

  2)SessionFactory接口:负责初始化Hibernate

  3)Session接口:负责持久化对象的CRUD操作

  4)Transaction接口:负责事务

  5)Query接口和Criteria接口:负责执行各种数据库查询

  问:hibernate处理过程

  答:1)通过Configuration config = new Configuration().configure();//读取并解析hibernate.cfg.xml配置文件

  2)由hibernate.cfg.xml中的读取并解析映射信息

  3)通过SessionFactory sf = config.buildSessionFactory();//创建SessionFactory

  4)Session session = sf.openSession();//打开Sesssion

  5)Transaction tx = session.beginTransaction();//创建并启动事务Transation

  6)persistent operate操作数据,持久化操作

  7)tx.commit();//提交事务

  8)session.close();关闭Session

  9)sf.close()关闭SesstionFactory

  问:事务的特性

  答:1)原子性(atomic),事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行

  2)一致性(consistent),事务在完成时,必须使所有的数据都保持一致状态

  3)隔离性(insulation),由并发事务所作的修改必须与任何其它并发事务所作的修改隔离

  4)持久性(Duration),事务完成之后,它对于系统的影响是永久性的

  问:数据库事务并发可能带来的问题

  答:1)第一类丢失更新(lost update): 在完全未隔离事务的情况下,两个事物更新同一条数据资源某一事物异常终止,回滚造成第一个完成的更新也同时丢失。

  2)脏读(dirty read):如果第二个事务查询到第一个事务还未提交的更新数据,形成脏读

  3)不可重复读(unrepeated read):一个事务两次读取同一行数据,结果得到不同状态结果如中间正好另一个事务更新了该数据,两次结果相异,不可信任

  4) 第二类丢失更新(second lost updates):是不可重复读的特殊情况,如果两个事务都读取同一行,然后两个都进行写操作,并提交,第一个事务所做的改变就会丢失

  问:为了解决数据库事务并发运行时的各种问题数据库系统提供四种事务隔离级

  答:1)Serializable 串行化

  2)Repeatable Read 可重复读

  3)Read Commited 可读已提交

  4)Read Uncommited 可读未提交

  问:Hibernate悲观锁解决事务并发问题

  答:一个典型的依赖数据库的悲观锁调用:select * from account where name="Erica" for update这条sql语句锁定了account表中所有符合检索条件name=Erica的记录

  问:Hibernate为乐观锁提供了3中实现

  答:1)基于version

  2)基于timestamp

  3)为遗留项目添加添加乐观锁

  问:Hibernate 的缓存体系

  答:1)一级缓存: Session 有一个内置的缓存,其中存放了被当前工作单元加载的对象,每个Session 都有自己独立的缓存,且只能被当前工作单元访问

  2)二级缓存: SessionFactory的外置的可插拔的缓存插件。其中的数据可被多个Session共享访问SessionFactory的内置缓存:存放了映射元数据,预定义的Sql语句

  问:Hibernate 中Java对象的状态

  答:1)临时状态(transient)特征:不处于Session 缓存中,数据库中没有对象记录,

  填写下面表单即可预约申请免费试听java课程!害怕学不会?助教全程陪读,随时解惑!担心就业?一地学习,可全国推荐就业!

  Java如何进入临时状态

  通过new语句刚创建一个对象时

  当调用Session 的delete()方法

  从Session 缓存中删除一个对象时

  2)持久化状态(persisted)特征:处于Session 缓存中,持久化对象数据库中设有对象记录,Session 在特定时刻会保持二者同步

  Java如何进入持久化状态

  Session 的save()把临时-》持久化状态

  Session 的load(),get()方法返回的对象

  Session 的find()返回的list集合中存放的对象

  Session 的update(),saveOrupdate()使游离-》持久化

  3)游离状态(detached)特征:不再位于Session 缓存中,游离对象由持久化状态转变而来,数据库中可能还有对应记录

  Java如何进入持久化状态-》游离状态

  Session 的close()方法

  Session 的evict()方法,从缓存中删除一个对象

  问:Hibernate中get和load有什么不同之处

  答:1)Hibernate的get方法,会确认一下该id对应的数据是否存在,首先在session缓存中查找然后在二级缓存中查找,还没有就查询数据库,数据库中没有就返回null

  2)Hibernate的load方法加载实体对象的时候,根据映射文件上类级别的lazy属性的配置(默认为true):

  ①若为true,则首先在Session缓存中查找,看看该id对应的对象是否存在,不存在则使用延迟加载

  返回实体的代理类对象(该代理类为实体类的子类,由CGLIB动态生成)。等到具体使用该对象(除获取OID以外)的时候

  再查询二级缓存和数据库,若仍没发现符合条件的记录,则会抛出一个ObjectNotFoundException

  ②若为false,就跟Hibernate的get方法查找顺序一样,只是最终若没发现符合条件的记录

  则会抛出一个ObjectNotFoundException,所说的load方法抛异常是指在使用该对象的数据时

  数据库中不存在该数据时抛异常,而不是在创建这个对象时

  问:Hibernate中save、update和saveOrUpdate方法的不同之处

  答:1)save:执行保存操作的,对一个新new出来的对象进行保存,数据库中没有这个对象,如果数据库中有,会报错说有重复的记录

  2)update:如果是对一个已经存在的托管对象进行更新,要使用update方法了,数据中有这个对象

  3)saveOrUpdate:这个方法是更新或者插入,有主键就执行更新,如果没有主键就执行插入。是根据实体类对象的状态做的不同操作

  ①实体类对象为临时态时做的添加save操作

  ②实体类对象为游离态、持久态时做的修改update操作

  问:cascade关系有以下几种

  答:1)all: 所有情况下均进行关联操作,即save-update和delete

  2)none: 所有情况下均不进行关联操作。这是默认值

  3)save-update: 在执行save/update/saveOrUpdate时进行关联操作

  4)delete: 在执行delete 时进行关联操作

  5)all-delete-orphan: 当一个节点在对象图中成为孤儿节点时,删除该节点

  问:什么是懒加载

  答: 1)Lazy:延迟加载,在真正使用某个对象的时候才正真的去创建,即hibernate才会正真的发出sql语句去加载该对象

  2)Lazy的有效期:只有在session打开的时候才有效;session关闭后lazy就没效了

  lazy策略可以用在:

  ①标签上:可以取值true/false

  ②标签上,可以取值true/false,这个特性需要类增强

  问:Hibernate 中inverse的属性

  答:hibernate配置文件中有这么一个属性inverse,它是用来指定关联的控制方的inverse属性默认是false,若为false,则关联由自己控制,若为true,则关联。

分享到

相关资讯