ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

@DataJpaTest 进行测试的坑

2022-08-26 02:02:04  阅读:148  来源: 互联网

标签:数据库 默认 DataJpaTest 测试 使用 注解 主键 进行


@DataJpaTest 这个注解主要用来在 Spring 项目中测试 JPA 数据源。

默认情况下,带有 @DataJpaTest 注解的测试使用嵌入式内存数据库。

因此 @DataJpaTest 这个注解还是有点坑的。

默认数据库

默认采用的是嵌入的 H2 数据库。

就算你配置了数据库链接,如果你不使用下面的注解的话,@DataJpaTest 还是会使用配置的默认数据库。

使用注解:

@AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)

来让你的程序只使用你提供的数据库连接来进行连接。

事务

@DataJpaTest 具有事务性,会自动回滚插入数据。

如果你的不进行配置的话,你会发现你插入的数据没有办法在数据库中出现。

解决办法就是在方法中,提供 @Commit 注解。

2022-08-25_08-21-32

然后再对数据库中的数据进行校验,这个时候数据是不会回滚的。

从日志中,我们也可以看到,插入的数据被回滚了。

 

2022-08-25_08-22-17

 

当我们提供 Commit 这个注释后,在日志中明确的提示已经提交了。

 

2022-08-25_08-23-40

 

表 hibernate_sequence

这是因为我们在数据库实体类配置的时候,没有指定主键策略。

在默认情况使用的是 Auto。

如果使用 Auto,Hibernate 将会使用 Oracle 的方式来自增的。

如果需要使用 Mysql 的话,你的实体类需要将主键策略修改为:

@GeneratedValue(strategy = GenerationType.IDENTITY)

因为我们实体类使用了继承 AbstractPersistable。

 

2022-08-25_08-27-28

 

因此我们可以通过修改 application.properties 来实现。

将参数设置为 false

spring.jpa.hibernate.use-new-id-generator-mappings=false

 

2022-08-25_08-28-14

 

这样就会对主键的策略进行修改了,我们就可以避免上面的这个问题了。

 

https://www.ossez.com/t/datajpatest/14070

标签:数据库,默认,DataJpaTest,测试,使用,注解,主键,进行
来源: https://www.cnblogs.com/huyuchengus/p/16626318.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有