微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Spring Boot@DataJpaTest H2嵌入式数据库创建模式

如何解决Spring Boot@DataJpaTest H2嵌入式数据库创建模式

我遇到了同样的问题,我设法通过使用内容创建schema.sql(在resources文件夹中)来解决

CREATE SCHEMA IF NOT EXISTS <yourschema>

可以在这里找到文档但是恕我直言,缺少实际示例使它变得非常复杂。警告:该脚本也在正常(非测试)环境中执行。

不是强制性的,而是一种很好的做法,仅在测试范围内添加h2依赖项

<dependency>
   <groupId>com.h2database</groupId>
   <artifactId>h2</artifactId>
   <scope>test</scope>
</dependency>

解决方法

我的数据层中有几个实体以特定的架构存储。例如:

@Entity
@Table(name = "FOO",schema = "DUMMY")
public class Foo {}

我正在尝试设置H2嵌入式数据库以对我的数据层进行集成测试。我在@DataJpaTest测试中使用注释来自动配置H2嵌入式数据库。但是,表的创建失败,因为DUMMY未在数据库初始化时创建架构。

关于在测试用例中创建表之前如何创建模式的任何想法?

我尝试使用@Sql(statements =“如果不存在则创建模式”),但未成功。

此外,我试图设置spring.datasource.url = jdbc:h2:mem:test;INIT=CREATE SCHEMA IF NOT EXISTS DUMMY在我的test.properties文件一起TestPropertySource("classpath:test.properties"),但没有工作过。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。