乐观锁:
大多数基于数据版本(version)记录机制实现,一般通过在数据库表中增加一个version字段实现
读取数据时将版本号一同读出,之后更新时对版本号加一。如果提交的数据小于数据库中当前版本号,
则认为是过期数据,否则给予更新。
悲观锁测试
悲观锁的实现,通常依靠数据库提供的机制,在整个处理过程中,将数据处于锁定状态;
例如:
select * from t_user where name="张三" for update
大多数基于数据版本(version)记录机制实现,一般通过在数据库表中增加一个version字段实现
读取数据时将版本号一同读出,之后更新时对版本号加一。如果提交的数据小于数据库中当前版本号,
则认为是过期数据,否则给予更新。
悲观锁测试
悲观锁的实现,通常依靠数据库提供的机制,在整个处理过程中,将数据处于锁定状态;
例如:
select * from t_user where name="张三" for update
<hibernate-mapping>
<class name="com.bjsxt.hibernate.User" optimistic-lock="version">
<id name="id">
<generator class="uuid"/>
</id>
<version name="version"/>
<property name="name"/>
<property name="password"/>
<property name="createTime"/>
<property name="expireTime"/>
</class>
</hibernate-mapping>
package com.bjsxt.hibernate;
import java.util.Date;
import org.hibernate.LockMode;
import org.hibernate.Session;
import junit.framework.TestCase;
public class PessimisticLockingTest extends TestCase {
public void testUpdate1() {
Session session = null;
try {
session = HibernateUtils.getSession();
session.beginTransaction();
User user = (User)session.load(User.class, "4028808114389f880114389f8ba50001", LockMode.UPGRADE);
System.out.println("name=" + user.getName());
System.out.println("password=" + user.getPassword());
user.setPassword("a");
session.update(user);
session.getTransaction().commit();
}catch(Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
}finally {
HibernateUtils.closeSession(session);
}
}
public void testUpdate2() {
Session session = null;
try {
session = HibernateUtils.getSession();
session.beginTransaction();
User user = (User)session.load(User.class, "4028808114389f880114389f8ba50001", LockMode.UPGRADE);
System.out.println("name=" + user.getName());
System.out.println("password=" + user.getPassword());
user.setPassword("b");
session.update(user);
session.getTransaction().commit();
}catch(Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
}finally {
HibernateUtils.closeSession(session);
}
}
}