mapper:java
<select id="queryLock" resultType="java.util.Map">
select upg,version from happy_lock
</select>
<update id="editHappyLock" parameterType="java.util.Map">
update happy_lock
set upg=#{upg},version=version+1
where id=#{id} and version=#{version};
</update>
測試:
@Test
public void happyLock() {
ExecutorService fixedThreadPool = Executors.newFixedThreadPool(20);
for(int i=0;i<10;i++){
fixedThreadPool.execute(new Runnable() {
@Override
public void run() {
try{
Map<String, Object> map = new HashMap<>();
map.put("id", 1);
Random rand = new Random();
Map<String,Object> mapTemp=nyHappyLockService.queryLock();
int randomCount=rand.nextInt(100);
int upg = Integer.valueOf(mapTemp.get("upg").toString());
int version = Integer.valueOf(mapTemp.get("version").toString());
map.put("version", version);
map.put("upg", (randomCount+version));
int count=nyHappyLockService.editHappyLock(map);
System.out.println(Thread.currentThread()+" "+Thread.currentThread().getName()+" 執行的結果數"+count);
}catch (Exception e){
e.printStackTrace();
}
}
});
}
}
執行結果:
提交的數據 版本號大於數據庫表當前版本號,更新。能夠看到後面的線程版本號都低於第一個版本 只有第一個執行成功後面的 都廢棄了數據庫