缓存
1、缓存:提高效率,hibernate中的一级缓存也是为了提高操作数据库的效率。
2、提高效率-手段1:提高查询效率
3、提高效率-手段2:减少不必要的修改语句发送
事务
1、事务特性
a:原子性 c:一致性 i:隔离性 d:持久性
2、事务并发问题
① 事务并发问题 ② 不可重复度 ③ 幻|虚读
3、事务的隔离级别
读未提交 - > ①②③
读未提交 - > ①②③
可重复读(mysql默认级别) - > ③
串行化 - > 没有问题
一、如何在hibernate中指定数据库的隔离级别?
<!-- 指定hibernate操作数据库时的隔离级别
#hibernate.connection.isolation 1|2|4|8
0001 1 读未提交
0010 2 读已提交
0100 4 可重复读
1000 8 串行化
-->
<property name="hibernate.connection.isolation">4</property>
二、在项目中如何管理事务?
1、业务开始之前打开事务,业务执行之后提交事务。执行过程中出现异常,回滚事务
2、在dao层操作数据库需要用到session对象,在service控制事务也是使用session对象完成。我们要确保dao层和service层使用的使用同一个session对象
3、在hibernate中,确保使用同一个session的问题,hibernate已经帮我们解决了。我们开发人员只需要调用sf.getCurrentSession()方法即可获得与当前线程绑定的session对象
注意1:调用getCurrentSession方法必须配合主配置中的一段配置
<!-- 指定session与当前线程绑定 -->
<property name="hibernate.current_session_context_class">thread</property>
注意2:通过getCurrentSession方法获得的session对象。当事务提交时,session会自动关闭.不要手动调用close关闭
service层:
public void save(Customer c) {
Session session = HibernateUtils.getCurrentSession();
//打开事务
Transaction tx = session.beginTransaction();
//调用Dao保存客户
try {
customerDao .save(c);
} catch (Exception e) {
e.printStackTrace();
tx.rollback();
}
//关闭事务
tx.commit();
}
Dao层:
public void save(Customer c) {
//1 获得session
Session session = HibernateUtils.getCurrentSession();
//3 执行保存
session.save(c);
}