📄 pessimisticlockdaobean.java
字号:
package com.foshanshop.ejb3.impl;
import javax.ejb.Remote;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.Query;
import com.foshanshop.ejb3.PessimisticLockDAO;
import com.foshanshop.ejb3.bean.User;
/**
* 使用悲观锁避免更新丢失
*/
@Stateless
@Remote(PessimisticLockDAO.class)
public class PessimisticLockDAOBean implements PessimisticLockDAO {
@PersistenceContext protected EntityManager em;
public void init(User user) {
em.persist(user);
}
public void payElectricityFee(int id) {//交电费
try {
Query query = em.createNativeQuery("select * from users where id=? FOR UPDATE", User.class);
User user = (User)query.setParameter(1, id).getSingleResult();
Thread.sleep(5000);//等待存工资事务开启
user.setBalance(user.getBalance()-200);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public void saveLaborage(int id) {//存工资
Query query = em.createNativeQuery("select * from users where id=? FOR UPDATE", User.class);
User user = (User)query.setParameter(1, id).getSingleResult();
user.setBalance(user.getBalance()+13000);
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -