私は春のブートコードに問題があります。私は@Transactionalアノテーションで分離レベルを理解しようとすると、このコードを与えられている:分離レベル再読可能スプリングブート
//BookingService class bookingService2 instance
@Transactional(isolation = Isolation.REPEATABLE_READ)
public String readConstantly() throws InterruptedException {
String name = "";
for(int i=0; i<2; i++) {
name = jdbcTemplate.query("select FIRST_NAME from BOOKINGS where ID=1", (rs, rowNum) -> rs.getString("FIRST_NAME")).get(0);
logger.info("Read name " + name);
Thread.sleep(1000);
}
return name;
}
このコード:
//BookingService class bookingService instance
@Transactional
public void updateOne(){
jdbcTemplate.update("update BOOKINGS set FIRST_NAME = ? where ID = 1", "zz");
}
ような実行の:
new Thread(() -> {
try {
bookingService2.readConstantly();
} catch (InterruptedException e) {
e.printStackTrace();
}
}).start();
bookingService.updateOne();
私はupdateOneを期待しますreadConstantlyトランザクションが終了するまで待つが、私がそれを呼び出すと、これが出力される:
2016-11-30 12:29:15.158 INFO 6456 --- [ Thread-3] hello.BookingService : Read name Alice
2016-11-30 12:29:16.158 INFO 6456 --- [ Thread-3] hello.BookingService : Read name zz
この場合、分離レベルではあまり効果がないのはなぜですか?
あなたはどのデータベースを使用していますか? – dimitrisli
入れ子のH2データベースを使用しています –