沉溺于追求物质享受,就等于给飞鸟的双翅系上了黄金——佚名

直接改依赖:

1
2
3
4
5
6
7
8
9
10
11
12
<!--<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<version>${h2.version}</version>
<scope>test</scope>
</dependency>-->
<dependency>
<groupId>org.hsqldb</groupId>
<artifactId>hsqldb</artifactId>
<version>2.7.1</version>
<scope>test</scope>
</dependency>

随便运行一个test报错:

image-20230212222807012

这里提到了关键字:TestDatabaseAutoConfiguration

我们进入org.springframework.boot.test.autoconfigure.jdbc.TestDatabaseAutoConfiguration$EmbeddedDataSourceFactory.getEmbeddedDatabase(TestDatabaseAutoConfiguration.java:191)

发现这里连接为空才会抛异常

image-20230212223548155

那我们ctrl+f8断点打在if这里,shift+f9debug一下

发现进入了EmbeddedDatabaseConnection.get

image-20230212223815174

F7再回车,深入get方法,发现这里的逻辑是如果driverClass存在,则返回对应的连接枚举EmbeddedDatabaseConnection,我们等待hsqldriverClass驱动

image-20230212224200317

f7看下ClassUtils.isPresent,发现是forName

按下f8发现直接到抛出异常返回false了,此时我们丢帧

image-20230212224412070

回到了外面

image-20230212224438056

再按下f7进去,ctrl+w选中forName和参数,按下alt+f8,发现了真正的报错

image-20230212224553965

1
org/hsqldb/jdbc/JDBCDriver has been compiled by a more recent version of the Java Runtime (class file version 55.0), this version of the Java Runtime only recognizes class file versions up to 52.0

image-20230212224610959

大概意思就是说不支持当前java版本了

我们换个早一点的依赖试试:

1
2
3
4
5
6
<dependency>
<groupId>org.hsqldb</groupId>
<artifactId>hsqldb</artifactId>
<version>2.5.2</version>
<scope>test</scope>
</dependency>

成功运行下来

image-20230212225254629

之后的报错就很容易解决了,是原来H2ddl(Data Definition Language)COMMENT关键字不支持,我们用正则替换掉

ctrl+r打开替换框,alt+x打开正则模式,输入正则后,按下alt+a替换全部

1
2
3
// 以COMMENT开头,直到遇到","为止,我们这里替换为空即可
COMMENT[^,]+
COMMENT[^,]*

image-20230212230052485

我们再试试另一个正则

1
2
// 以[ COMMENT ' ]开头,以'结尾,我们这里替换为空即可
COMMENT '.*'

再次运行,发现不支持NULL DEFAULT xxx格式,替换掉DEFAULT前面的NULL

image-20230212231509792

再次运行,发现不支持无SQL不执行查询,而是会报错

image-20230212231705849

而且不支持CASE field WHEN conditionValue THEN actualValue的语法

image-20230212232854860

因此换回H2了,ctrl+alt+z,选择pom.xml,按下alt+r或者直接回车

image-20230212232949229