我已经在application.properties中设置了spring.datasource.*:
spring.datasource.url=jdbc:h2:./data/test
spring.datasource.username=sa
spring.datasource.password=
spring.datasource.driver-class-name=org.h2.Driver
然后我配置了JdbcTemplate Bean
@Bean
@Autowired
public JdbcTemplate jdbcTemplate(DataSource dataSource) {
return new JdbcTemplate(dataSource);
}
但是当我启动应用程序时,我在控制台中看到
Starting embedded database: url='jdbc:h2:mem:testdb;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=false', username='sa'
而不是我的设置。为什么?
它总是有魔力。
当问题发生时,我有这些依赖性:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
</dependency>
但是当我把它改为
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
</dependency>
问题消失了...
解决你的问题
下面是示例片段。
@EnableAutoConfiguration(exclude=DataSourceAutoConfiguration.class)
@ImportResource({ "classpath:datasource-config.xml"})
public class Sample {
在 datasource-config.xml 中,您也可以使用数据源属性文件。
享受:-)
我也遇到了同样的问题,希望对你有帮助。
问题似乎是:
当您登录 H2 控制台时,它会将元数据写入您的用户文件夹 (.h2.server.properties)。该文件仅配置控制台 UI 中显示的内容。
请密切注意您在控制台 UI 的
JDBC URL
字段中输入的 URL。它必须与您在 spring.datasource.url
文件的 application.properties
中定义的 URL 匹配。
技巧是:当仅运行示例应用程序时,它不会创建数据文件,直到您将某些内容连接/提交到数据库中。所以,您认为
autoconfigure feature
没有完成这项工作。
但是当您第一次修改数据库状态时,H2 在右侧文件夹中创建数据文件something.mv.db
。
假设您刚刚创建了一个具有以下依赖项的新应用程序(即
JDBC
、H2
和 web
),请尝试以下操作来了解我的观点:
1)设置你的 pom.xml (这是我提到的这三个依赖项的默认值):
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.example</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>demo</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.0.BUILD-SNAPSHOT</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
<repositories>
<repository>
<id>spring-snapshots</id>
<name>Spring Snapshots</name>
<url>https://repo.spring.io/snapshot</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>spring-snapshots</id>
<name>Spring Snapshots</name>
<url>https://repo.spring.io/snapshot</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
</pluginRepository>
<pluginRepository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</pluginRepository>
</pluginRepositories>
</project>
2)在application.properties文件中:
spring.h2.console.enabled=true
spring.h2.console.path=/h2-console
spring.datasource.url=jdbc:h2:file:./data/test
3) 打开文件资源管理器窗口以显示项目根文件夹的内容(与您的
pom.xml
相同的文件夹)。
4) 然后,转到
<server>:8080/h2-console
。
在控制台 UI 的 JDBC URL
字段中,键入:jdbc:h2:file:./data/test
并连接。
5) 您将看到正在创建的“data”文件夹,在本例中是数据文件
test.mv.db
。
如果你想在控制器类中注入
JdbcTemplate
,
private final JdbcTemplate jdbcTemplate;
@Autowired
public MyController(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
通过这种方式,您可以在任何 Spring bean 中自动装配
jdbcTemplate
。
在您的
pom.xml
中添加 spring boot jdbc 依赖项
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
请参阅此 spring boot 文档 了解更多信息。
我在使用 spring boot 3.4.1 时遇到了同样的问题,并通过在 application.properties 中添加 spring.test.database.replace=none 来修复它