Spring 弹簧靴不';不要使用数据源属性
我已经在application.properties中设置了spring.datasource.*:Spring 弹簧靴不';不要使用数据源属性,spring,spring-boot,database-connection,spring-jdbc,properties-file,Spring,Spring Boot,Database Connection,Spring Jdbc,Properties File,我已经在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 然后我配置了jdbcbean模板 @Bean @Autowired public JdbcTem
spring.datasource.url=jdbc:h2:./data/test
spring.datasource.username=sa
spring.datasource.password=
spring.datasource.driver-class-name=org.h2.Driver
然后我配置了jdbcbean模板
@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'
而不是我的设置。为什么?您的问题的解决方案
@EnableAutoConfiguration(exclude=DataSourceAutoConfiguration.class)
@ImportResource({“classpath:datasource config.xml”})
公共类示例{
如果要在控制器类中插入
JdbcTemplate
private final JdbcTemplate jdbcTemplate;
@Autowired
public MyController(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
通过这种方式,您可以在任何Springbean中自动连接jdbcTemplate
在pom.xml
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
org.springframework.boot
了解更多信息。这总是一种魔力
出现问题时,我有以下依赖项:
<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>
org.springframework.boot
弹簧靴起动器
org.springframework
SpringJDBC
com.h2数据库
氢
但是当我把它换成
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
</dependency>
org.springframework.boot
弹簧靴启动器jdbc
com.h2数据库
氢
问题消失了…我也有同样的问题,希望它能帮助你
问题似乎是:
当您登录到H2控制台时,它会在您的用户文件夹(.H2.server.properties)中写入元数据。此文件仅配置控制台UI中显示的内容
请密切注意您在控制台UI的JDBC URL
字段中输入的URL。它必须与您在application.properties
文件的spring.datasource.URL
中定义的URL相匹配
诀窍是:当只运行一个示例应用程序时,它不会创建一个数据文件,直到您将某些内容连接/提交到数据库中。因此,您认为自动配置功能不起作用。
但是,当您第一次修改数据库状态时,H2会在正确的文件夹中创建数据文件something.mv.db
假设您刚刚创建了一个具有以下依赖项的新应用程序(即JDBC
、H2
和web
),请尝试以下内容来了解我的观点:
1) 设置pom.xml(这是我提到的这三个依赖项的默认值):
3) 打开文件资源管理器窗口以显示项目根文件夹的内容(与pom.xml
的文件夹相同)
4) 然后,转到:8080/h2控制台
。
在控制台UI的JDBC URL
字段中,键入:JDBC:h2:file:./data/test
和连接
5) 您将看到正在创建的“data”文件夹及其内部,即本例中的数据文件test.mv.db
。谢谢您的回答,但我正在编写desckop应用程序,因此我没有WEB-INF目录。我也没有datasouce-config.xml,因为a看到了多个没有它的示例。无论如何,我在一个月前找到了一个解决方案,我将添加它作为回答,我的问题是为什么使用的url是jdbc:h2:mem:testdb;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=false
而不是我在application.properties
中指定的jdbc:h2:./data/test
。如果我的问题不清楚,我很抱歉。因为你的第二部分的答案是在我回答后2分钟添加的,我将接受我自己的答案。添加依赖性:org.springframework.boot-spring-boot-starter jdbc适合我,所以spring-boot-starter数据jpa是不够的
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
</dependency>
<?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>
spring.h2.console.enabled=true
spring.h2.console.path=/h2-console
spring.datasource.url=jdbc:h2:file:./data/test