乐观锁和悲观锁

悲观锁:
配置: Person p = (Person)session.load(Person.class, 2, LockMode.UPGRADE) ;
相当于发出一条sql语句并锁定该语句 .

9.
乐观锁机制
如何配置:
第一步:在person.hbm.xml中
<class name="com.cs.Person" table="t_PERSON" optimistic-lock="version" >
<id name="id" column="PERSON_ID">
<generator class="native"/>
</id>
<version name="version" />
<property name="age"/>
<property name="name" />
<property name="amount" />
</class>
类的设计:


public class Person {
private int id ;
private String name ;
private int age ;
private int version ;
private int amount ;

public int getAmount() {
return amount;
}
public void setAmount(int amount) {
this.amount = amount;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public int getVersion() {
return version;
}
public void setVersion(int version) {
this.version = version;
}
}

测试代码:
public static void getData2() {
Session session = null ;
Transaction tx = null ;
try {
session = HibernateUtil.getSessionFactory().getCurrentSession() ;
tx = session.beginTransaction() ;

Person p = (Person)session.load(Person.class, 2) ;
System.out.println(p.getId() + " " + p.getName() + " " + p.getAmount());
p.setAmount(p.getAmount() - 50000) ;

session.update(p) ;
tx.commit() ;
} catch (HibernateException e) {
if (tx != null) {
tx.rollback() ;
}
e.printStackTrace() ;
} finally {
HibernateUtil.closeSession() ;
}
}

原理解析:
假设有两个用户在同一时间并发访问:
用户a和b
假设person表中的字段version=0 ,amount=10000;
a用户上来取出version=0 ,amount=10000;
然后把version=1,amount=5000 ;
正在此时a尚未来得及提交,b用户上来,取出version=0,amount=10000;
之后a用户commit
发出Update Person set version=0+1 and amount=50000
Where id=2 and version=0
此时数据库中的version=1 ,amount=5000 ;
之后b用户也提交commit
发出Update Person set version=0+1 and amount=50000
Where id=2 and version=0
此时在数据库中已经不存在id=2 version=0的记录,所以提交失败,数据要回滚
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值