当前位置: 首页 > 知识库问答 >
问题:

使用Java配置时的Spring批处理表前缀

隆选
2023-03-14

我的Spring Batch存储库(部署在Oracle数据库上)位于不同的模式中,因此我需要在模式名称之前添加。

使用XML配置时,这很容易做到:

<job-repository id="jobRepository" table-prefix="GFA.BATCH_" />

但是,当我使用JavaConfig时,这变得更加棘手。我发现的最佳解决方案是让我的JavaConfig类扩展DefaultBatchConfigrer并覆盖createJobRepository()方法:

@Configuration
@EnableBatchProcessing
public class BatchConfiguration extends DefaultBatchConfigurer{
    @Autowired
    private DataSource dataSource;

    @Autowired
    private PlatformTransactionManager transactionManager;

    @Override
    protected JobRepository createJobRepository() throws Exception {
        JobRepositoryFactoryBean factory = new JobRepositoryFactoryBean();
        factory.setDataSource(dataSource);
        factory.setTransactionManager(transactionManager);
        factory.setTablePrefix("GFA.BATCH_");
        factory.afterPropertiesSet();
        return factory.getObject();
    }
...
}

与XML解决方案相比,这相当多的代码!这也不太符合逻辑——我的第一个猜测是提供一个< code>@Bean方法,如下所示:

@Bean
public JobRepository jobRepository() throws Exception {
    JobRepositoryFactoryBean factory = new JobRepositoryFactoryBean();
    factory.setDataSource(dataSource);
    factory.setTransactionManager(transactionManager);
    factory.setTablePrefix("GFA.BATCH_");
    factory.afterPropertiesSet();
    return factory.getObject();
}

但这没用。

我的问题是:我的解决方案是最佳的还是有更好的解决方案?我更喜欢定义一个Bean,而不是必须覆盖一些不太直观的类的方法......显然,如果我们可以缩短代码以有点接近XML配置中的单行代码,那就更好了。

共有2个答案

冯嘉珍
2023-03-14

您应该在java中定义BatchConfigurer,并在这个bean中定义spring批处理表前缀:

@Bean
    public BatchConfigurer batchConfigurer() {
        return new DefaultBatchConfigurer() {

            @Autowired
            PlatformTransactionManager platformTransactionManager;

            @Override
            protected JobRepository createJobRepository() throws Exception {
                JobRepositoryFactoryBean factory = new JobRepositoryFactoryBean();
                factory.setDataSource(secondaryDataSource(secondaryDataSourceProperties()));
                factory.setTransactionManager(platformTransactionManager);
                factory.setIsolationLevelForCreate("ISOLATION_READ_COMMITTED");
                factory.setTablePrefix(batchTablePrefix);
                factory.setDatabaseType("POSTGRES");
                factory.setMaxVarCharLength(maxVarcharSize);
                return factory.getObject();
            }
        };
郭浩穰
2023-03-14

只需将此行添加到在批处理配置上注册的任何属性文件中:

spring.batch.table-prefix= GFA.BATCH_

仅供参考,前缀< code>spring.batch与Spring boot提供的< code > org . Spring framework . boot . auto configure . batch . batch properties 相映射。参见github上的源代码。

 类似资料:
  • 我们正在处理一个Spring批处理项目(Spring Boot1.2.2.Release),要求使用Spring SFTP集成以一定频率轮询从服务器位置读取文件。我们使用java config实现了Spring批处理,并在使用Spring Integration java config的过程中实现了Spring批处理。我找不到描述上述情况的例子。我浏览了各种链接,但看到的主要是XML配置示例。 h

  • Spring Integration Java DSL Reference和Spring Batch Java配置文档说明了如何将Java配置用于Spring Integration和Spring Batch。 但它们没有说明如何为Spring批处理集成配置它。如何使用DSL配置JobLaunchingGateway? 干杯,曼诺

  • 我是新的Spring批与引导。我在使用postgres配置jobRepositoryFactory bean作为数据库时遇到了一个问题。下面是我的配置类。 下面是Spring boot App run的输出 我已经在我的configuration类中配置了bean。我错过了什么?

  • 我正在使用Spring批处理设置一个作业服务器。我的JdbcCursorItemReader需要配置sql,该sql在每个作业运行的基础上进行更改。因为sql发生了变化,所以我希望阅读器具有@stepscope,这样我就不需要担心sql的状态性了。 所以我设置了这样一个类: 我在整个服务器上使用基于Java的配置。ItemReader的一个实例的bean如下所示: 启动服务器并运行Spring批处

  • 我有下一个spring批处理配置类: 启动应用程序时,我收到下一个异常:

  • 如何使用Java配置实现这一点?