/* * Copyright 2004-2015 the Seasar Foundation and the Others. * * 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 org.seasar.extension.dataset.impl; import java.util.ArrayList; import java.util.List; import javax.sql.DataSource; import org.seasar.extension.dataset.DataReader; import org.seasar.extension.dataset.DataSet; import org.seasar.extension.dataset.DataTable; import org.seasar.extension.dataset.TableReader; /** * SQLを扱うための {@link DataReader}です。 * * @author higa * */ public class SqlReader implements DataReader { private DataSource dataSource; private List tableReaders = new ArrayList(); /** * {@link SqlReader}を作成します。 * * @param dataSource */ public SqlReader(DataSource dataSource) { this.dataSource = dataSource; } /** * データソースを返します。 * * @return データソース */ public DataSource getDataSource() { return dataSource; } /** * データセットを追加します。 * * @param dataSet * データセット */ public void addDataSet(DataSet dataSet) { for (int i = 0; i < dataSet.getTableSize(); i++) { DataTable table = dataSet.getTable(i); addTable(table.getTableName()); } } /** * テーブルを追加します。 * * @param tableName * テーブル名 */ public void addTable(String tableName) { addTable(tableName, null); } /** * テーブルを追加します。 * * @param tableName * テーブル名 * @param condition * 条件 */ public void addTable(String tableName, String condition) { SqlTableReader reader = new SqlTableReader(dataSource); reader.setTable(tableName, condition); tableReaders.add(reader); } /** * テーブルを追加します。 * * @param tableName * テーブル名 * @param condition * 条件 * @param sort * ソート条件 */ public void addTable(String tableName, String condition, String sort) { SqlTableReader reader = new SqlTableReader(dataSource); reader.setTable(tableName, condition, sort); tableReaders.add(reader); } /** * SQLを追加します。 * * @param sql * SQL * @param tableName * テーブル名 */ public void addSql(String sql, String tableName) { SqlTableReader reader = new SqlTableReader(dataSource); reader.setSql(sql, tableName); tableReaders.add(reader); } public DataSet read() { DataSet dataSet = new DataSetImpl(); for (int i = 0; i < tableReaders.size(); ++i) { TableReader reader = (TableReader) tableReaders.get(i); dataSet.addTable(reader.read()); } return dataSet; } }