io.gravitee.repository.jdbc.management.JdbcHelper Maven / Gradle / Ivy
/**
* Copyright (C) 2015 The Gravitee team (http://gravitee.io)
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.gravitee.repository.jdbc.management;
import org.springframework.jdbc.core.RowCallbackHandler;
import org.springframework.jdbc.core.RowMapper;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import static org.springframework.util.CollectionUtils.isEmpty;
/**
*
* @author njt
*/
public class JdbcHelper {
public static final String AND_CLAUSE = " and ";
public static final String WHERE_CLAUSE = " where ";
@FunctionalInterface
public interface ChildAdder {
void addChild(T parent, ResultSet rs) throws SQLException;
}
public static class CollatingRowMapper implements RowCallbackHandler {
private final RowMapper mapper;
private final ChildAdder childAdder;
private final String idColumn;
private final List rows;
private Comparable lastId;
private T current;
CollatingRowMapper(RowMapper mapper, ChildAdder childAdder, String idColumn) {
this.mapper = mapper;
this.childAdder = childAdder;
this.idColumn = idColumn;
this.rows = new ArrayList<>();
}
@Override
public void processRow(ResultSet rs) throws SQLException {
Comparable currentId = (Comparable)rs.getObject(idColumn);
if ((lastId == null) || (lastId.compareTo(currentId) != 0)) {
lastId = currentId;
current = mapper.mapRow(rs, rows.size() + 1);
rows.add(current);
}
childAdder.addChild(current, rs);
}
public List getRows() {
return rows;
}
}
public static class CollatingRowMapperTwoColumn implements RowCallbackHandler {
private final RowMapper mapper;
private final ChildAdder childAdder;
private final String idColumn1;
private final String idColumn2;
private final List rows;
private Comparable lastId1;
private Comparable lastId2;
private T current;
CollatingRowMapperTwoColumn(RowMapper mapper, ChildAdder childAdder, String idColumn1, String idColumn2) {
this.mapper = mapper;
this.childAdder = childAdder;
this.idColumn1 = idColumn1;
this.idColumn2 = idColumn2;
this.rows = new ArrayList<>();
}
@Override
public void processRow(ResultSet rs) throws SQLException {
Comparable currentId1 = (Comparable)rs.getObject(idColumn1);
Comparable currentId2 = (Comparable)rs.getObject(idColumn2);
if (
(lastId1 == null)
|| (lastId1.compareTo(currentId1) != 0)
|| (lastId2 == null)
|| (lastId2.compareTo(currentId2) != 0)
) {
lastId1 = currentId1;
lastId2 = currentId2;
current = mapper.mapRow(rs, rows.size() + 1);
rows.add(current);
}
childAdder.addChild(current, rs);
}
public List getRows() {
return rows;
}
}
static boolean addCondition(final boolean first, final StringBuilder builder, final String propName,
final Object propVal, final List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy