Spring 引导不使用数据源属性
Spring Boot doesn't use datasource properties
我在 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'
而不是我的设置。为什么?
您问题的解答
- SpringBoot 将始终只查找嵌入式数据源,请检查您的 WEB-INF/lib 路径中是否有任何其他驱动程序,如 derby 驱动程序。
- 您排除数据源配置并使用 importResource 注释注入您的数据源配置。
下面的示例代码段。
@EnableAutoConfiguration(exclude=DataSourceAutoConfiguration.class)
@ImportResource({ "classpath:datasource-config.xml"})
public class Sample { </pre>
在 datasource-config.xml 中,您也可以使用数据源属性文件。
享受:-)
如果你想在你的控制器中注入 JdbcTemplate
class,
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 documentation。
它总是一个魔法。
当问题发生时,我有这些依赖关系:
<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>
问题消失了...
我遇到了同样的问题,希望对你有帮助。
问题似乎是:
当您登录 H2 控制台时,它会将元数据写入您的用户文件夹 (.h2.server.properties)。该文件只是配置将在控制台中显示的内容 UI.
请密切注意您在控制台 UI 的 JDBC URL
字段中输入的 URL。它必须与您在 application.properties
文件的 spring.datasource.url
中定义的 URL 匹配。
诀窍是:当 运行 只是一个示例应用程序时,它不会创建数据文件,直到您 connect/commit 将某些内容放入数据库。所以,您认为 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) 打开文件资源管理器 window 以显示项目根文件夹的内容(与 pom.xml
相同的文件夹)。
4) 然后,转到<server>:8080/h2-console
。
在控制台 UI 的 JDBC URL
字段中,键入:jdbc:h2:file:./data/test
并连接。
5) 您将看到正在创建的 'data' 文件夹及其内部,在本例中为数据文件 test.mv.db
。
我在 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'
而不是我的设置。为什么?
您问题的解答
- SpringBoot 将始终只查找嵌入式数据源,请检查您的 WEB-INF/lib 路径中是否有任何其他驱动程序,如 derby 驱动程序。
- 您排除数据源配置并使用 importResource 注释注入您的数据源配置。
下面的示例代码段。
@EnableAutoConfiguration(exclude=DataSourceAutoConfiguration.class) @ImportResource({ "classpath:datasource-config.xml"}) public class Sample { </pre>
在 datasource-config.xml 中,您也可以使用数据源属性文件。
享受:-)
如果你想在你的控制器中注入 JdbcTemplate
class,
private final JdbcTemplate jdbcTemplate;
@Autowired
public MyController(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
通过这种方式,您可以在任何 spring bean 中自动装配 jdbcTemplate
。
在你的 pom.xml
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
有关详细信息,请参阅此 spring boot documentation。
它总是一个魔法。
当问题发生时,我有这些依赖关系:
<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>
问题消失了...
我遇到了同样的问题,希望对你有帮助。
问题似乎是:
当您登录 H2 控制台时,它会将元数据写入您的用户文件夹 (.h2.server.properties)。该文件只是配置将在控制台中显示的内容 UI.
请密切注意您在控制台 UI 的 JDBC URL
字段中输入的 URL。它必须与您在 application.properties
文件的 spring.datasource.url
中定义的 URL 匹配。
诀窍是:当 运行 只是一个示例应用程序时,它不会创建数据文件,直到您 connect/commit 将某些内容放入数据库。所以,您认为 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) 打开文件资源管理器 window 以显示项目根文件夹的内容(与 pom.xml
相同的文件夹)。
4) 然后,转到<server>:8080/h2-console
。
在控制台 UI 的 JDBC URL
字段中,键入:jdbc:h2:file:./data/test
并连接。
5) 您将看到正在创建的 'data' 文件夹及其内部,在本例中为数据文件 test.mv.db
。