是否可以在没有
XML的情况下为作业设置
Spring Batch?
目前,XML中定义了很多这样的作业bean:
<bean id="sampleJob" class="com.test.job.TestJob">
<property name="idBase" value="SampleId" />
<property name="targetTableName" value="SAMPLE_TABLE" />
<property name="sql">
<value><![CDATA[
SELECT 42 FROM 1337
]]></value>
</property>
</bean>
Spring Batch每晚都在我们的应用程序中运行.我希望能够编辑作业的属性.我们的想法是从数据库中获取注入的属性,而不是用XML对它们进行硬编码.
如果您对如何解决问题有更好的了解,请告诉我.目前,我想实现一种提供类似方法的工厂:
public TestJob createJob(String name) {
String sql = db.getSqlFor(name);
String table = db.getTableFor(name);
...
return new TestJob(sql, table, ...);
}
Spring Batch是否提供这些可能性?我google了很多但没有找到令人满意的解决方案.
提前致谢!
最佳答案 有可能的.只需使用SpringBatch提供的不同构建器即可动态创建作业.
他们使用的步骤和所有读者和作者不一定是春豆(当然,在这种情况下,没有自动装配,这迫使你自己这样做).
@Configuration
public class SimpleJobConfiguration {
private static final String JOB_NAME = "SimpleTestJob";
@Autowired
private JobBuilderFactory jobs;
@Autowired
private StepBuilderFactory steps;
@Bean
public Job job() throws Exception {
SimpleJobBuilder jobBuilder = this.jobs.get(createJobName(JOB_NAME)).start(firstStep());
for ... {
jobBuilder.next(createAStep( ... params ...));
}
return standardJob.build();
}
public Step createAStep(String name, ... needed parameters ...) throws Exception {
StepBuilder stepBuilder = this.steps.get(name);
build your step
return standardStep1.build();
}
}