maven test 执行测试用例,操作的是h2数据库,第二次执行提示表已存在

这个问题通常发生在使用H2内存数据库进行单元测试时。每次运行测试时,H2数据库都应该重新创建,但看起来在你的情况下,数据库状态在测试之间被保留了。让我们来解决这个问题:

  1. 检查数据库配置

首先,确保你的测试配置使用的是内存数据库。在你的测试资源目录下的 application.propertiesapplication.yml 文件中,数据库URL应该类似于:

spring.datasource.url=jdbc:h2:mem:testdb;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE

DB_CLOSE_DELAY=-1 确保数据库在最后一个连接关闭后不会立即关闭。

  1. 使用 @Transactional 注解

在你的测试类上添加 @Transactional 注解。这将使每个测试方法在事务中运行,并在测试结束时回滚事务:

@RunWith(SpringRunner.class)
@SpringBootTest
@Transactional
public class YourTestClass {
    // ...
}
  1. 手动清理数据库

在每个测试方法之前或之后清理数据库。你可以使用 @Before@After 注解:

@Before
public void setUp() {
    // 执行清理脚本
    jdbcTemplate.execute("DROP ALL OBJECTS");
}
  1. 使用 @DirtiesContext

如果你希望在每次测试运行后重新创建应用上下文,可以使用 @DirtiesContext 注解:

  1. 使用唯一的数据库名称

为每次测试运行使用唯一的数据库名称:

spring.datasource.url=jdbc:h2:mem:testdb_${random.uuid};DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE

这将为每次测试运行创建一个新的内存数据库。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值