开发工具分享
  • 首页
  • 计算科学
  • 文化旅游
  • 项目和网站
    • OSSEZ 计算技术
    • USRealEstate 社区
    • 地区文化
    • CWIKI.US
    • BUG.OSSEZ.COM
    • RSS.OSSEZ.COM
CWIKIUS.CN
一个有独立思考和温度的清新站
  1. Home
  2. Computer Science
  3. This article

@DataJpaTest 进行测试的坑

2022年08月28日 609Browse 0Like 0Comments

@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

Tags: None
Last updated:2022年08月28日

HoneyMoose

有温度的人文和独立的思考

Like
< Previous
Next >

Comments

Cancel reply

Archives
  • May 2026
  • April 2026
  • March 2026
  • February 2026
  • January 2026
  • December 2025
  • November 2025
  • October 2025
  • September 2025
  • August 2025
  • July 2025
  • June 2025
  • May 2025
  • April 2025
  • March 2025
  • February 2025
  • January 2025
  • December 2024
  • November 2024
  • October 2024
  • September 2024
  • August 2024
  • July 2024
  • June 2024
  • May 2024
  • April 2024
  • March 2024
  • February 2024
  • January 2024
  • December 2023
  • November 2023
  • October 2023
  • September 2023
  • August 2023
  • July 2023
  • June 2023
  • May 2023
  • April 2023
  • December 2022
  • November 2022
  • October 2022
  • September 2022
  • August 2022
  • May 2022
  • April 2022
  • March 2022
  • February 2022
  • January 2022
  • December 2021
  • November 2021
  • October 2021
  • September 2021
  • August 2021
  • July 2021
  • June 2021
  • May 2021
  • April 2021
  • March 2021
  • February 2021
  • January 2021
  • December 2020
  • November 2020
  • October 2020
  • September 2020
  • August 2020
  • July 2020
  • June 2020
  • May 2020
  • April 2020
  • March 2020
  • February 2020
  • January 2020
  • December 2019
  • November 2019
  • October 2019
  • September 2019
  • August 2019
  • July 2019
  • June 2019
  • May 2019
  • April 2019
  • March 2019
  • February 2019
  • January 2019
  • December 2018
  • November 2018
  • October 2018
  • September 2018
  • August 2018
  • July 2018
  • June 2018
  • May 2018
  • April 2018
  • March 2018
Categories
  • Computer Science (2,362)
    • Confluence (663)
    • Gradle (12)
  • U.S. (482)
  • 文化旅游 (145)

COPYRIGHT © 2020 CWIKIUS. ALL RIGHTS RESERVED.

THEME KRATOS MADE BY VTROIS

湘ICP备2020018253号-1