com.gs.obevocomparer.input.db.QueryDataSource Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of obevo-internal-comparer Show documentation
Show all versions of obevo-internal-comparer Show documentation
POM module containing the dependencyManagement section for the modules of Obevo.
All Obevo modules except obevo-bom should inherit from this. We separate obevo-bom from this so
that clients can depend on the BOM without pulling in third-party dependencies.
/**
* Copyright 2017 Goldman Sachs.
* 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 com.gs.obevocomparer.input.db;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import com.gs.obevocomparer.data.CatoDataObject;
import com.gs.obevocomparer.input.AbstractCatoDataSource;
public class QueryDataSource extends AbstractCatoDataSource {
private final Connection connection;
private final QueryExecutor queryExecutor;
private ResultSet rset;
private ResultSetMetaData rsetmd;
public QueryDataSource(String name, String url, String user, String password, String query) throws SQLException {
this(name, DriverManager.getConnection(url, user, password), query);
}
public QueryDataSource(String name, Connection connection, String query) {
this(name, connection, new SimpleQueryExecutor(query));
}
public QueryDataSource(String name, Connection connection, QueryExecutor queryExecutor) {
super(name, null);
this.connection = connection;
this.queryExecutor = queryExecutor;
}
protected CatoDataObject nextDataObject() throws Exception {
if (!this.rset.next()) {
return null;
}
CatoDataObject dataObject = this.createDataObject();
for (int i = 1; i < this.rsetmd.getColumnCount() + 1; i++) {
dataObject.setValue(this.rsetmd.getColumnLabel(i), this.rset.getObject(i));
}
return dataObject;
}
protected void closeSource() throws Exception {
this.rset.close();
this.queryExecutor.close();
this.connection.close();
}
protected void openSource() throws Exception {
this.rset = this.queryExecutor.getResultSet(this.connection);
this.rsetmd = this.rset.getMetaData();
}
public Connection getConnection() {
return this.connection;
}
/**
* Functional interface for executing a query. Different clients of QueryDataSource may have more advanced logic
* for query execution.
*/
public interface QueryExecutor {
ResultSet getResultSet(Connection connection) throws Exception;
void close() throws Exception;
}
/**
* Default implementation using simple JDBC.
*/
private static class SimpleQueryExecutor implements QueryExecutor {
private final String query;
private Statement stmt;
private SimpleQueryExecutor(String query) {
this.query = query;
}
@Override
public ResultSet getResultSet(Connection connection) throws Exception {
this.stmt = connection.createStatement();
return this.stmt.executeQuery(query);
}
@Override
public void close() throws Exception {
if (stmt != null) {
this.stmt.close();
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy