Java面试题之Hibernate

简介: Java面试题之Hibernate1.简书一下Hibernated的开发流程 第一步:加载Hibernate的配置文件,读取配置文件的参数, 第二步:创建SessionFactory会话工厂(内部有连接池) 第三步:打开Session 连接 第四步:开启事务...

Java面试题之Hibernate

1.简书一下Hibernated的开发流程

    第一步:加载Hibernate的配置文件,读取配置文件的参数,
    第二步:创建SessionFactory会话工厂(内部有连接池)
    第三步:打开Session 连接
    第四步:开启事务
    第五步:运行操作
    第六步:提交事务
    第七步:关闭session
    第八步:关闭连接池

2.Hibernate 中对对象的三种状态

瞬时状态:不存在持久化标识的OID,尚未与HibernateSession对象关联,被认为处于瞬时状态,失去引用将被JVM回收
持久态:存在持久标识OID,与当前session有关联,并且相关联Session没有关闭,并且事务未提交
游离态:存在持久化标识OID,但没有与当前Session关联,

3.Hibernate的缓存机制

Hibernate缓存机制分为两层,Hibernate的一级缓存和Hibernate二级缓存。
1.Hibernate一级缓存(Session的缓存)

Session 实现了第一级Cache,属于事务级数据缓冲,一旦事务结束,缓存随之失效,一个Session的生命周期对应一个数据库事务或一个程序事务。

    Session-Cache总是被打开并且不能被关闭的

Session-Cache 保证一个Session中两次请求同一个对象时,取得的对象是一个Java实例,有时他可以避免数据不必要的冲突

Hibernate 二级缓存(SessionFactory的缓存)

(1)Hibernate 二级缓冲是SessionFactory范围内的缓存,所有的Session共享一个二级缓存,在二级缓存中保存持久化实例

    的散装形式的数据

(2)持久化不同的数据需要不同的Cache 策略,比如一些因素影响Cache策略的选择:数据的读写比例,数据表能否被其他的应用程序所访问等。

设置Hibernate 二级缓存需要分两步,首先,确认使用什么数据并发策略,然后,配置缓存期间时间并设置Cache提供器
Hibernate的查询方式常见有三种:HQL,QBC(命名查询),以及使用原生SQL查询

Hibernate和JDBC优缺点对比

相同点:
        1)两者都是java数据库操作的中间件
        2)两者对数据库进行直接操作的对象时线程不安全的,都需及时关闭
        3)两者都可对数据库的更新操作进行显示的事务处理
    使用的SQL语言不同:JDBC使用是基于关系型数据库的标准SQL语言。HIbernate使用是HQL语言
    操作的对象不同:JDBC操作的是数据,将数据通过SQL语句直接发送的数据库中执行,Hibernate操作的是持久化对象,有第吃了个持久化对象的数据更新到数据库中
    数据状态不同:JDBC操作的数据时瞬时的,变量的值无法与数据库中值保持一致,而Hibernate操作的数据时可持久化的,即持久化对象的数据属性的值是可以跟数据库中的值保持一致
关于Hibernate的orm思想你了解多少?
ORM指的是对象关系型映射,指的就是我们通过创建实体类对象和数据库中的表关系进行一一对应,来实现通过操作实体类对象来更改数据库里边的数据信息,这里边起到关键作用的是通过HIbernate的映射文件+Hibernate的核心配置文件

get和load的区别

1.get是立即加载,load是延时加载

2.get会先查一级缓存,在查二级缓存,然后查数据库;load会先查一级缓存,如果没找到,就创建代理对象,等需要的时候去查询二级缓存和数据库,(这里体现load的延迟加载的特性)

3.get如果没有找到会返回null,load如果没有找到会抛出异常

4.当我们使用session.load方法加载一个对象时,此时并不会发出SQL语句,当前得到得这个对象其实是一个代理对象。这个代理对象只保存了实体对象的id值,只有当我们使用这个对象,得到其它属性时,这个时候才会发出SQL语句,从数据库中去查询我们的对对象,相当于load的延迟加载方式。get就直接的多,当我们使用Session.get()方法来得到一个对象时,不管我们使不使用这个对象,此时都会发出SQL语句从数据库中查询出来

如何进行Hibernate 的优化

1.数据库设计调整。

2.HQL优化

3.API的正确使用

4.主配置参数(日志,查询缓存,fetch_sieze,batch_size).

5。映射文件优化(ID生成策略,二级缓存,延迟加载,关联优化)

6.一级缓存的管理

7.针对二级缓存,还有许多特有的策略

8.事务控制策略

相关文章
|
3天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
16 2
|
8天前
|
存储 算法 Java
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
本文详解自旋锁的概念、优缺点、使用场景及Java实现。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
|
14天前
|
存储 缓存 Oracle
Java I/O流面试之道
NIO的出现在于提高IO的速度,它相比传统的输入/输出流速度更快。NIO通过管道Channel和缓冲器Buffer来处理数据,可以把管道当成一个矿藏,缓冲器就是矿藏里的卡车。程序通过管道里的缓冲器进行数据交互,而不直接处理数据。程序要么从缓冲器获取数据,要么输入数据到缓冲器。
Java I/O流面试之道
|
9天前
|
SQL Java 数据库连接
从理论到实践:Hibernate与JPA在Java项目中的实际应用
本文介绍了Java持久层框架Hibernate和JPA的基本概念及其在具体项目中的应用。通过一个在线书店系统的实例,展示了如何使用@Entity注解定义实体类、通过Spring Data JPA定义仓库接口、在服务层调用方法进行数据库操作,以及使用JPQL编写自定义查询和管理事务。这些技术不仅简化了数据库操作,还显著提升了开发效率。
21 3
|
10天前
|
存储 缓存 Java
大厂面试必看!Java基本数据类型和包装类的那些坑
本文介绍了Java中的基本数据类型和包装类,包括整数类型、浮点数类型、字符类型和布尔类型。详细讲解了每种类型的特性和应用场景,并探讨了包装类的引入原因、装箱与拆箱机制以及缓存机制。最后总结了面试中常见的相关考点,帮助读者更好地理解和应对面试中的问题。
33 4
|
11天前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
50 4
|
1月前
|
存储 安全 算法
Java面试题之Java集合面试题 50道(带答案)
这篇文章提供了50道Java集合框架的面试题及其答案,涵盖了集合的基础知识、底层数据结构、不同集合类的特点和用法,以及一些高级主题如并发集合的使用。
83 1
Java面试题之Java集合面试题 50道(带答案)
|
18天前
|
缓存 Java 数据库连接
Hibernate:Java持久层框架的高效应用
通过上述步骤,可以在Java项目中高效应用Hibernate框架,实现对关系数据库的透明持久化管理。Hibernate提供的强大功能和灵活配置,使得开发者能够专注于业务逻辑的实现,而不必过多关注底层数据库操作。
12 1
|
23天前
|
存储 Java 程序员
Java面试加分点!一文读懂HashMap底层实现与扩容机制
本文详细解析了Java中经典的HashMap数据结构,包括其底层实现、扩容机制、put和查找过程、哈希函数以及JDK 1.7与1.8的差异。通过数组、链表和红黑树的组合,HashMap实现了高效的键值对存储与检索。文章还介绍了HashMap在不同版本中的优化,帮助读者更好地理解和应用这一重要工具。
50 5
|
22天前
|
存储 Java
[Java]面试官:你对异常处理了解多少,例如,finally中可以有return吗?
本文介绍了Java中`try...catch...finally`语句的使用细节及返回值问题,并探讨了JDK1.7引入的`try...with...resources`新特性,强调了异常处理机制及资源自动关闭的优势。
18 1