【发布时间】:2020-03-04 15:42:58
【问题描述】:
我的目标是使用 spring 批处理 tasklet 中的自定义行映射器查询存储过程 (sql server) 的结果。
我正在使用 Spring Boot(版本 2.2.2.RELEASE)和 Spring Batch(4.2.1.RELEASE)。
例子:
存储过程:
CREATE PROCEDURE storedProcName @numbers VARCHAR(max), @day DATE
AS
SET NOCOUNT ON;
SELECT something, something2, something3
FROM sometable
WHERE ids in (select value from string_split(@numbers,','))
AND day = @day
自定义行映射器:
public class CustomRowMapper implements RowMapper<CustomObject> {
private static final String SOMETHING = "something";
private static final String SOMETHING2 = "something2";
private static final String SOMETHING3 = "something3";
@Override
public CustomObject mapRow(ResultSet resultSet, int i) throws SQLException {
CustomObject customObject = new CustomObject();
customObject.setSomething(resultSet.getString(SOMETHING));
customObject.setSomething2(resultSet.getString(SOMETHING2));
customObject.setSomething3(resultSet.getInt(SOMETHING3));
return customObject;
}
}
执行存储过程并查询结果:
SimpleJdbcCall jdbcCall = new SimpleJdbcCall(jdbcTemplate)
.withProcedureName("storedProcName")
.returningResultSet("test", new CustomRowMapper());
Map<String, Object> out = jdbcCall.execute(parameterSource);
List<CustomObject> customObjects = (List<CustomObject>) out.get("test");
它工作正常,但必须有更有效的方法来做到这一点?但我没有发现任何有用的东西。
【问题讨论】:
标签: sql-server spring stored-procedures spring-batch spring-jdbc