gpt4 book ai didi

postgresql - 使用 postgres 进行 Spring Batch 自动配置

转载 作者:行者123 更新时间:2023-11-29 11:51:42 25 4
gpt4 key购买 nike

我正在尝试使用 PosgreSQL 作为数据库的普通 Spring 批处理应用程序。

pom.xml:-

<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.3.3.RELEASE</version>
<relativePath /> <!-- lookup parent from repository -->
</parent>

<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<java.version>1.8</java.version>
</properties>

<dependencies>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.6</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-batch</artifactId>
<exclusions>
<exclusion>
<artifactId>hsqldb</artifactId>
<groupId>org.hsqldb</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.batch</groupId>
<artifactId>spring-batch-test</artifactId>
<scope>test</scope>
</dependency>

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

<dependency>
<groupId>org.postgresql</groupId>
<artifactId>postgresql</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>

我已明确排除“hsqldb”以确保 Spring 批处理使用 posgres。添加此依赖项可以解决问题,但我不想在我的设置中使用 hsqldb。

配置类:-

@SpringBootApplication
@EnableBatchProcessing
public class Application {

private static Logger LOG = LoggerFactory.getLogger(Application.class);

public static void main(String[] args) {

SpringApplication.run(Application.class, args);
}

}

应用程序.yml

spring:
application:
name: theapp
batch:
job:
enabled: false
profiles:
active: local

---

spring:
profiles: local
data:
mongodb:
host: localhost
database: dbname
datasource:
username: postgres
password: password
driverClassName: org.postgresql.Driver
url: jdbc:postgresql://localhost:5432/org.postgresql.Driver

---

spring:
profiles: abc
data:
mongodb:
database: dbname
host: abc.com
datasource:
username: postgres
password: password
url: jdbc:postgresql://abc.com:5432/dbname
driver-class-name: org.postgresql.Driver

Junit 类:-

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = { Application.class })
@ActiveProfiles(profiles = { "local" })
public class BillingEngineBatchTest {

@Test
public void test() {
Assert.assertNotNull("");
}

}

问题

如何告诉 Spring Batch 使用 postgres 而不是嵌入式数据库?

在应用程序启动期间,我收到一条异常消息:“原因:org.springframework.boot.autoconfigure.jdbc.DataSourceProperties$DataSourceBeanCreationException:无法确定数据库类型为 NONE 的嵌入式数据库驱动程序类。”

Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [javax.sql.DataSource]: Factory method 'dataSource' threw exception; nested exception is org.springframework.boot.autoconfigure.jdbc.DataSourceProperties$DataSourceBeanCreationException: Cannot determine embedded database driver class for database type NONE. If you want an embedded database please put a supported one on the classpath. If you have database settings to be loaded from a particular profile you may need to active it (the profiles "local" are currently active).
at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:189)
at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:588)
... 77 more
Caused by: org.springframework.boot.autoconfigure.jdbc.DataSourceProperties$DataSourceBeanCreationException: Cannot determine embedded database driver class for database type NONE. If you want an embedded database please put a supported one on the classpath. If you have database settings to be loaded from a particular profile you may need to active it (the profiles "local" are currently active).

最佳答案

如果你使用的是 postgres 那么你可能需要在你的 pom.xml 中:

<dependency>
<groupId>postgresql</groupId>
<artifactId>postgresql</artifactId>
<version>9.1-901.jdbc4</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>

我希望这能解决你的问题

关于postgresql - 使用 postgres 进行 Spring Batch 自动配置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35773651/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com