您的位置:首页 > 数据库

Junit进行数据库操作时事务自动回滚

2017-09-03 17:58 316 查看
今天用Junit在测试service时发现,对数据进行修改时不报错,但是去数据库查询发现数据并没有更新,困惑了一段时间,代码如下


@Test
public void testAddOrUpdateUserEmail() {
Long result = (long) userService.addOrUpdateUserEmail("777", "127.0.0.1",
"个人中心-test", "添加邮箱", "aa");
}


juni运行正常,使用debug数据填充也没问题,但是数据库里的数据并没有更新,代码修改为如下:


@Test
public void testAddOrUpdateUserEmail() {
Long result = (long) userService.addOrUpdateUserEmail("777", "127.0.0.1",
"个人中心-test", "添加邮箱", "aa");
User user = userMapper.selectByPrimaryKey("770517");
System.out.println("------>user:" + user.getUsername() + user.getEmail());
}


这时候再debug可以查询出打印结果显示已更新,去数据库查询发现还是没有变化,此时怀疑是事务的回滚,查了资料后发现项目使用的Junit基类继承于AbstractTransactionalJUnit4SpringContextTests


@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = { "classpath:app-initconfig-excdubbo-test.xml" })
public class BaseExcludeDubboTest extends AbstractTransactionalJUnit4SpringContextTests{
/**
* @description
*/
@Test
public void testEmpty(){

}
}


AbstractTransactionalJUnit4SpringContextTests默认操作修改、新增、删除操作是事务自动回滚,避免出现脏数据,如果不需要回滚,可以添加@Rollback(false)注解即可。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐