2 a779712764 a779712764 于 2016.05.06 13:04 提问

当事务进行到一半时web服务器挂了
@Transactional(propagation=Propagation.REQUIRED)
public void test(){
    financialDao.createObj(new Financial(null,40076L));
    financialDao.createObj(new Financial(null,40077L));
    financialDao.createObj(new Financial(null,40078L));
    financialDao.createObj(new Financial(null,40079L));
    financialDao.createObj(new Financial(null,40080L));
    try {
        Thread.sleep(20000);
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    financialDao.createObj(new Financial(null,40081L));
    financialDao.createObj(new Financial(null,40082L));
    financialDao.createObj(new Financial(null,40083L));
}

中间睡眠20秒是让我自己有时间关闭服务器,是用来模拟服务器挂掉的时候当前操作只进行了一部分,服务器挂了之后睡眠前的数据持久化到数据库了,睡眠后的数据没有持久化到数据库,我想不明白是什么原因,我觉得既然他方法都没执行完成,就应该没有进行事务的提交,睡眠前和睡眠后的操作都不应该持久化到数据库。请哪位高人来指点一下 说说这其中的一些情况,感激不尽。

2个回答

qq_24515921
qq_24515921   2016.05.06 13:25
已采纳

数据库在你关闭服务器的时候会自动检查内存中的脏数据的,然后将这些脏数据持久化到数据库的,而且你做了DML操作之后不需要等待commit才会提交到硬盘写入的

a779712764
a779712764 非常感谢
一年多之前 回复
mazegong
mazegong   2016.05.06 15:33

数据库在你关闭服务器的时候会自动检查内存中的脏数据的,然后将这些脏数据持久化到数据库的,而且你做了DML操作之后不需要等待commit才会提交到硬盘写入的

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!