C3P0连接池
- 导入C3P0的jar包
- hibernate.cfg.xml 配置

<!-- 配置C3P0连接池 -->
<property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
<!--
-->
<property name="hibernate.c3p0.max_size">2</property>
事务回顾
- 事务:一组业务操作,要么全部成功,要么全部不成功。
- 特性:ACID
- 隔离问题:
- 脏读:一个事务读到另一个事务未提交的内容
- 不可重复读:一个事务读到另一个事务已提交的内容(insert)
- 虚读(幻读):一个事务读到另一个事务已提交的内容(update)
- 隔离级别–解决问题
- read uncommittd,读未提交。存在3个问题。
- read committed,读已提交。解决:脏读。存在2个问题。
- repeatable read ,可重复读。解决:脏读、不可重复读。存在1个问题。
- serializable,串行化。单事务。没有问题。
- hibernate设置隔离级别
- 在hibernate.cfg.xml 配置:hibernate.connection.isolation 4

悲观锁
- 简介:假设每次最坏的情况,每次去拿数据的时候都会认为别人会修改,所以每次在拿数据的时候都会上锁。
- 读锁:在读取过程中,不希望别人修改,并且自己也不会修改,就可以给读取的数据加入读锁。
- 读锁可被其他线程所共享,如果是读取的话大家都可以用这把锁读到数据.
- select * from table lock in share mode(读锁、共享锁)
- 写锁:不仅要读数据,还要对数据进行修改,就可以为读取的数据加上写锁。
- 写锁不能共享,只要有人为数据加入了写锁,其他人就不能为数据加任何锁.
- select * from table for update (写锁、排它锁)
- Hibernate中的代码:
public class Demo2 {
@Test
public void fun1(){
Session session = HibernateUtils.openSession();
session.beginTransaction();
Customer c
= (Customer) session.get(Customer.class, 1, LockOptions.UPGRADE);
System.out.println(c);
session.getTransaction().commit();
session.close();
}
@Test
public void fun2(){
Session session = HibernateUtils.openSession();
session.beginTransaction();
Customer c
= (Customer) session.get(Customer.class, 1, LockOptions.READ);
System.out.println(c);
session.getTransaction().commit();
session.close();
}
乐观锁
- 简介:总是假设最好的情况,每次去拿数据的时候都会认为别人不会修改,所以每次在拿数据的时候不会上锁。