我有两个步骤
<batch:step id="parseXML" next="commitSQL">
<batch:tasklet>
<batch:chunk reader="bookListReader" writer="xmlBookListWriter" commit-interval="1"/>
</batch:tasklet>
</batch:step>
<batch:step id="commitSQL">
<batch:tasklet ref="databaseItemWriter"/>
</batch:step>
我对代码没有任何问题,但步骤commitSQL
根本没有执行,只有步骤parseXML
无限运行。
我的读者代码
@Override
public List<Book> read() throws Exception, UnexpectedInputException, ParseException,
NonTransientResourceException {
// TODO Auto-generated method stub
System.out.println("I am reading :) :)");
List<Book> bookList = new ArrayList<>();
bookList.add(new Book("Java","Cay","McGrall","1234"));
bookList.add(new Book("E Java","Cay","McGrall","1234"));
return bookList;
}
和编写器代码
private static void convertBookListToXML(List<? extends Book> books) throws IOException {
List<Book> bookList = getBookList(books);
try {
System.out.println("I am writer :) :)");
JAXBContext jaxbContext = JAXBContext.newInstance(Books.class);
Marshaller xmlMarshaller = jaxbContext.createMarshaller();
xmlMarshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, Boolean.TRUE);
BufferedWriter writer = new BufferedWriter(new FileWriter(BOOK_FILE));
xmlMarshaller.marshal(new Books(bookList), writer);
writer.close();
} catch (JAXBException e) {
e.printStackTrace();
}
}
代表parseXML
,但commitSQL
的代码根本没有执行。有任何建议我将如何parseXML
出来并继续commitSQL
答案 0 :(得分:1)
在基于块的步骤中,一旦所有输入都用尽,则认为步骤完成。这由ItemReader
表示,返回null。在你的读者的情况下,你永远不会返回null,所以它将永远运行。
答案 1 :(得分:0)
我认为读者会返回List,这是正确的。 Spring-Batch编写器应该包含一个write方法,并且位于ItemWriter接口的层次结构中。从问题中给出的代码示例中看不到这一点。
也许最简单的方法就是查看Spring-Batch手册。 6.7.2对于StaxEventItemWriter上的示例,还有很多可以通过Google找到此编写器的示例。