我在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'
而不是我的设置。为什么呢?
答案 0 :(得分:5)
它始终是一种魔力。
当问题发生时,我有这些依赖项:
<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>
问题消失了......
答案 1 :(得分:1)
我遇到了同样的问题,希望对你有帮助。
问题似乎是:
当您登录H2控制台时,它会在您的用户文件夹(.h2.server.properties)中写入元数据。此文件仅配置将在控制台UI中显示的内容。
密切关注您在控制台用户界面的JDBC URL
字段中输入的网址。它必须与您在spring.datasource.url
文件的application.properties
中定义的网址匹配。
诀窍是:当只运行一个示例应用程序时,它不会创建数据文件,直到您将某些内容连接/提交到数据库中。所以,你认为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
。
在控制台用户界面的JDBC URL
字段中,键入:jdbc:h2:file:./data/test
和连接。
5)在这种情况下,您将看到正在创建的'data'文件夹及其中的数据文件test.mv.db
。
答案 2 :(得分:0)
解决您的问题
以下示例代码段。
@EnableAutoConfiguration(exclude=DataSourceAutoConfiguration.class)
@ImportResource({ "classpath:datasource-config.xml"})
public class Sample {
在datasource-config.xml中,您也可以使用数据源属性文件。
享受: - )
答案 3 :(得分:0)
如果要在控制器类中注入JdbcTemplate
,
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。