- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在开发 springboot API,我和我的同事决定在开发过程中使用 H2 嵌入式数据库。
数据库在启动应用程序时可以正常生成,但我无法使其在单元测试期间工作:它们都失败,并显示 org.h2.jdbc.JdbcSQLException: Table '[...]' not找到了
。
我基本上没有编写大部分代码,如果您需要更多,请告诉我:
application.properties
文件,H2 数据库在其中初始化:
datasources.member-request.url=jdbc:h2:mem:db;IGNORECASE=TRUE;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE;INIT=CREATE SCHEMA IF NOT EXISTS DMDEOWNER\\;SET SCHEMA DMDEOWNER\\;runscript from 'classpath:h2_init_script.sql'
datasources.member-request.username=sa
datasources.member-request.password=
datasources.member-request.driver-class-name=org.h2.Driver
datasources.member-request.initialize=true
正如你在上面看到的,我们在 H2 初始化时执行一个名为 h2_init_script.sql
的 SQL 脚本,在这个文件中我们有一些像这样的 SQL 语句(我将向你展示 T_THEME 表例如)
/* CREATE statements */
CREATE TABLE DMDEOWNER.T_THEME (
F_NUM_THEME NUMBER(14) NOT NULL,
F_REF_THEME VARCHAR2(30) NOT NULL,
F_LIB_THEME VARCHAR2(50) NOT NULL,
F_POS_THEME NUMBER(4) NOT NULL,
F_BOOL_ACTIF NUMBER(1) NOT NULL,
F_UTILISATEUR_MAJ VARCHAR2(40) NOT NULL,
F_DT_CREATION DATE NOT NULL,
F_DT_MAJ DATE,
PRIMARY KEY (F_NUM_THEME)
);
/* INSERT statements */
/* ... */
这是我的测试类(及其父类):
public class ThemeRepositoryTest extends AbstractRepositoryTest {
private final static int NB_ACTIVE_ENTITIES = 2;
private final static int NB_INACTIVE_ENTITIES = 1;
@Autowired
private ThemeRepository repository;
@Autowired
private ThemeMapper mapper;
// -------------------------------------------------------------------------
// CREATE
// -------------------------------------------------------------------------
@Before
public void init() {
for (int i = INTEGER_ZERO; i < NB_ACTIVE_ENTITIES; i++) {
insertTheme(true);
}
for (int i = INTEGER_ZERO; i < NB_INACTIVE_ENTITIES; i++) {
insertTheme(false);
}
entityManager.flush();
}
// -------------------------------------------------------------------------
// READ
// -------------------------------------------------------------------------
@Test
public void findAll() {
List<ThemeEntity> list = repository.findAll();
assertEquals(NB_ACTIVE_ENTITIES + NB_INACTIVE_ENTITIES, list.size());
}
}
@RunWith(SpringRunner.class)
@DataJpaTest
public abstract class AbstractRepositoryTest {
@Autowired
protected TestEntityManager entityManager;
protected ThemeEntity insertTheme(boolean active) {
ThemeEntity entity = newThemeEntity(3L, "NAME", active, "USER");
return entityManager.merge(entity);
}
}
这是我的错误发生的地方,当我调用 insertTheme()
时,在 init()
函数中:
findAll(io.lacipav.repository.ThemeRepositoryTest) Time elapsed: 0.227 s <<< ERROR!
javax.persistence.PersistenceException: org.hibernate.exception.SQLGrammarException: could not prepare statement
at io.lacipav.repository.ThemeRepositoryTest.init(ThemeRepositoryTest.java:38)
Caused by: org.hibernate.exception.SQLGrammarException: could not prepare statement
at io.lacipav.repository.ThemeRepositoryTest.init(ThemeRepositoryTest.java:38)
Caused by: org.h2.jdbc.JdbcSQLException:
Table "T_THEME" not found; SQL statement:
select themeentit0_.f_num_theme as f_num_th1_11_0_, themeentit0_.f_bool_actif as f_bool_a2_11_0_, themeentit0_.f_dt_creation as f_dt_cre3_11_0_, themeentit0_.f_dt_maj as f_dt_maj4_11_0_, themeentit0_.f_lib_theme as f_lib_th5_11_0_, themeentit0_.f_pos_theme as f_pos_th6_11_0_, themeentit0_.f_ref_theme as f_ref_th7_11_0_, themeentit0_.f_utilisateur_maj as f_utilis8_11_0_ from t_theme themeentit0_ where themeentit0_.f_num_theme=? [42102-197]
at io.lacipav.repository.ThemeRepositoryTest.init(ThemeRepositoryTest.java:38)
由于错误告诉我它没有找到我的表,我猜测这是因为在构建 .war
文件时我的数据库没有运行,如果是这样怎么办我可以更快地初始化它吗?
编辑:根据要求,这是 T_THEME 的实体类:
@Entity
@Getter
@Setter
@Table(name = "T_THEME")
public class ThemeEntity {
/** Primary key of the table. */
@Id
@NotNull
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "theme_generator")
@SequenceGenerator(name = "theme_generator", sequenceName = "SEQ_NUM_THEME", allocationSize = 1)
@Column(name = "f_num_theme")
private Long idTechnique;
/** Theme functional identifier */
@NotNull
@Column(name = "f_ref_theme")
private String reference;
/** Theme simple short length label */
@NotNull
@Column(name = "f_lib_theme")
private String name;
//...
}
注意:生成 SQL 序列“SEQ_NUM_THEME”并将其关联到 SQL 脚本中的 F_NUM_THEME。
编辑2:
正如 Lesiak 指出的,我的错误可能来自于我的 DataSource 被注释 @DataJpaTest
替换。通过仔细观察日志,我发现了一些有趣的行。
[INFO ] 2019-05-24 16:22:20.341 [main] org.springframework.boot.test.autoconfigure.jdbc.TestDatabaseAutoConfiguration$EmbeddedDataSourceBeanFactoryPostProcessor.process(TestDatabaseAutoConfiguration.java:106) : Replacing 'dataSource' DataSource bean with embedded version
[INFO ] 2019-05-24 16:22:20.346 [main] org.springframework.beans.factory.support.DefaultListableBeanFactory.registerBeanDefinition(DefaultListableBeanFactory.java:824) : Overriding bean definition for bean 'dataSource' with a different definition: replacing [Root bean: class [null]; scope=; abstract=false; lazyInit=false; autowireMode=3; dependencyCheck=0; autowireCandidate=true; primary=false; factoryBeanName=org.springframework.boot.autoconfigure.jdbc.DataSourceConfiguration$Hikari; factoryMethodName=dataSource; initMethodName=null; destroyMethodName=(inferred); defined in class path resource [org/springframework/boot/autoconfigure/jdbc/DataSourceConfiguration$Hikari.class]] with [Root bean: class [org.springframework.boot.test.autoconfigure.jdbc.TestDatabaseAutoConfiguration$EmbeddedDataSourceFactoryBean]; scope=; abstract=false; lazyInit=false; autowireMode=0; dependencyCheck=0; autowireCandidate=true; primary=false; factoryBeanName=null; factoryMethodName=null; initMethodName=null; destroyMethodName=null]
[INFO ] 2019-05-24 16:22:21.050 [main] org.springframework.jdbc.datasource.embedded.EmbeddedDatabaseFactory.initDatabase(EmbeddedDatabaseFactory.java:189) : Starting embedded database: url='jdbc:h2:mem:4ef27020-c472-4be9-a9af-73f5e0175846;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=false', username='sa'
我们可以在最后一行看到我的url连接jdbc:h2:mem:db
已被jdbc:h2:mem:4ef27020-c472-4be9-a9af-73f5e0175846替换
。这可能就是为什么我收到一些 Table not found
错误的原因。
最佳答案
问题在于您正在使用的@DataJpaTest
。请参阅Documentation of @DataJpaTest
By default, tests annotated with @DataJpaTest will use an embedded in-memory database (replacing any explicit or usually auto-configured DataSource). The @AutoConfigureTestDatabase annotation can be used to override these settings.
你会在日志中找到类似的内容
EmbeddedDataSourceBeanFactoryPostProcessor : Replacing 'dataSource' DataSource bean with embedded version
要修复,请使用:
spring.test.database.replace=none
spring.jpa.properties.hibernate.default_schema=DMDEOWNER
关于java - Mockito单元测试时如何生成H2嵌入式数据库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56290532/
这个问题困扰了我几天。 这是我的相关 Storyboard布局: 我已经将阳光下的每个布局都设置为所有三个 View Controller ,并且仍然得到一个在横幅 View 上方有一个“间隙”的结果
我正在我的 C++ 程序中嵌入一个网页。我遇到的问题是,在嵌入式页面的 javascript 中,我可以捕获 onkeypress,但不会触发 onkeydown 和 onkeyup。 如果我在非嵌入
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 5年前关闭。 Improve this qu
我有一个 java web 应用程序。我想创建一个嵌入式 LDAP 服务器,当 web 应用程序运行时,我将向 LDAP 插入一些记录,并且有另一个 web 应用程序将访问此 LDAP 以获取信息。可
我正在尝试通过 tomcat maven 插件将 war 部署到嵌入式 tomcat 服务器。控制台显示服务器启动正常。 看来 war 还没有展开。当我访问 http://localhost:9090
假设我有如下函数: bigrams=[(k,v) for (k,v) in dict_bigrams.items() if k[:pos_qu]==selection[:pos_qu
我读过一些关于 python 嵌入式 C++ 的教程。我曾引用过 python 对象。 https://docs.python.org/3/c-api/function.html Python 脚本:
我正在使用嵌入式应用程序,在调试期间,调试器无法解析宏符号(我的理论:因为宏在预处理中丢失了)。我最终不得不先在源代码中找到宏,然后使用定义来监视变量。 我的问题是:有没有办法将宏定义合并到 elf
首先我要说的是我开发的是基于cortex m4的嵌入式设备应用。 我有引导加载程序和主应用程序通用的功能。现在我为引导加载程序和应用程序编译源文件 2 次。但是我的双库 dfu 空间不足,我想在 RO
作为嵌入式 C 编程的初学者,我很好奇每个(根据我的经验)程序执行是如何从 main() 函数开始的?这就像链接器识别 main() 并将那个“特殊” 函数的地址放入重置 vector 指向的地址。
在我的实时嵌入式处理器固件中,我需要十进制数字的格式化打印。标准 printf/sprintf 在工具链中不可用,所以我需要自己实现它。 我使用了除以十并取余的天真方法。但是我的目标处理器本身不支持除
我有编程经验,但在软件开发方面了解不多。我目前正在为我工作的公司编写一个软件,我开始挑战自己代码的可读性。 我想知道这是否是嵌入式 if 语句的“有效”替代方案,或者我是否可以使用更好的方法。 假
我有一个运行嵌入式 Linux 的嵌入式目标,我想计算以下时间: 1) 高速缓存读/写时序2) uncache 内存读/写时序 Linux 中是否有任何标准测试来计算上述时间? 我已经编写了自己的测试
大多数嵌入式设备都是为了在通常资源受限或低规格的设备上执行特定任务而构建的。 因此,大多数嵌入式开发人员需要去除不必要的库和模块,并为其特定设备和用例创建自定义分发。我们先来了解一下嵌入式 Linu
我正在嵌入式处理器上编写一个简单的裸机应用程序。作为此应用程序的一部分,它必须使用 malloc 在大约 256kB 的堆上分配一些内存。注意:最初这是在 main 中静态分配的,但在一定的大小限制下
我正在尝试为我 friend 的婚礼建立一个网站。我使用的是 Bootstrap 5,嵌入的视频没有填满屏幕大小。这是一个 live test page HTML: 您还需要代码吗?我想让视频的全宽
我有一个项目,我尝试为微 Controller 构建固件并尝试更好地控制所使用的优化标志。我想,而不是使用 -O flag 分别指定不同的优化标志。不幸的是,-O 似乎发生了一些优化魔法。我无法使用单
我正在使用双核设备,并且要求核心 A 创建一个数据结构,其中包含在核心 B 上运行的函数列表的参数,定期更新它并通知核心 B。参数和类型的数量可以改变在运行期间。 我的计划如下.. 创建一个 Para
我们有一个 Microsoft.Phone.Controls.WebBrowser内嵌控件 StackPanel , 在 PivotItem 内在 Windows Phone 8 上。以简化的形式,它
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 2 年前。 Improve this ques
我是一名优秀的程序员,十分优秀!