All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.jpattern.orm.session.SqlPerformer Maven / Gradle / Ivy

package com.jpattern.orm.session;

import java.math.BigDecimal;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import com.jpattern.logger.ILogger;
import com.jpattern.orm.exception.OrmException;
import com.jpattern.orm.exception.OrmNotUniqueResultException;
import com.jpattern.orm.logger.OrmLogger;

/**
 * 
 * @author Francesco Cina
 *
 * 02/lug/2011
 */
public class SqlPerformer implements ISqlPerformer {

	private final ILogger logger = OrmLogger.getOrmLogger(getClass());
	private final ISqlPerformerStrategy sqlPerformerTemplate;
	private int queryTimeout = 0;
	private int maxRows = 0;
	
	public SqlPerformer(ISqlPerformerStrategy sqlPerformerTemplate) {
		this.sqlPerformerTemplate = sqlPerformerTemplate;
	}
	
	@Override
	public final void setMaxRows(int maxRows) {
		logger.debug("setMaxRows", "max rows sets to " + maxRows);
		this.maxRows = maxRows;
	}

	@Override
	public final int getMaxRows() {
		return maxRows;
	}

	@Override
	public final void setQueryTimeout(int queryTimeout) {
		logger.debug("setQueryTimeout", "queryTimeout sets to " + queryTimeout);
		this.queryTimeout = queryTimeout;
	}

	@Override
	public final int getQueryTimeout() {
		return queryTimeout;
	}
	
	@Override
	public final Integer queryForInt(String sql, Object... values) throws OrmException, OrmNotUniqueResultException {
		IResultSetReader resultSetReader = new IResultSetReader() {

			@Override
			public Integer read(ResultSet resultSet) throws SQLException {
				if ( resultSet.next() ) {
					int result = resultSet.getInt(1);
					if (resultSet.next()) {
						throw new OrmNotUniqueResultException("The query execution returned a number of rows higher than 1");
					}
					return result;
				}
				return null;
			}
		};
		return query(sql, resultSetReader, values);
	}

	@Override
	public final Long queryForLong(String sql, Object... values) throws OrmException, OrmNotUniqueResultException {
		IResultSetReader resultSetReader = new IResultSetReader() {

			@Override
			public Long read(ResultSet resultSet) throws SQLException {
				if ( resultSet.next() ) {
					long result = resultSet.getLong(1) ;
					if (resultSet.next()) {
						throw new OrmNotUniqueResultException("The query execution returned a number of rows higher than 1");
					}
					return result;
				}
				return null;
			}
		};
		return query(sql, resultSetReader, values);
	}
	
	@Override
	public final Double queryForDouble(String sql, Object... values) throws OrmException, OrmNotUniqueResultException {
		IResultSetReader resultSetReader = new IResultSetReader() {

			@Override
			public Double read(ResultSet resultSet) throws SQLException {
				if ( resultSet.next() ) {
					double result = resultSet.getDouble(1) ;
					if (resultSet.next()) {
						throw new OrmNotUniqueResultException("The query execution returned a number of rows higher than 1");
					}
					return result;
				}
				return null;
			}
		};
		return query(sql, resultSetReader, values);
	}

	@Override
	public final Float queryForFloat(String sql, Object... values) throws OrmException, OrmNotUniqueResultException {
		IResultSetReader resultSetReader = new IResultSetReader() {

			@Override
			public Float read(ResultSet resultSet) throws SQLException {
				if ( resultSet.next() ) {
					float result = resultSet.getFloat(1) ;
					if (resultSet.next()) {
						throw new OrmNotUniqueResultException("The query execution returned a number of rows higher than 1");
					}
					return result;
				}
				return null;
			}
		};
		return query(sql, resultSetReader, values);
	}

	@Override
	public final String queryForString(String sql, Object... values) throws OrmException, OrmNotUniqueResultException {
		IResultSetReader resultSetReader = new IResultSetReader() {

			@Override
			public String read(ResultSet resultSet) throws SQLException {
				if ( resultSet.next() ) {
					String result = resultSet.getString(1) ;
					if (resultSet.next()) {
						throw new OrmNotUniqueResultException("The query execution returned a number of rows higher than 1");
					}
					return result;
				}
				return null;
			}
		};
		return query(sql, resultSetReader, values);
	}

	@Override
	public final Boolean queryForBoolean(String sql, Object... values) throws OrmException, OrmNotUniqueResultException {
		IResultSetReader resultSetReader = new IResultSetReader() {

			@Override
			public Boolean read(ResultSet resultSet) throws SQLException {
				if ( resultSet.next() ) {
					boolean result = resultSet.getBoolean(1) ;
					if (resultSet.next()) {
						throw new OrmNotUniqueResultException("The query execution returned a number of rows higher than 1");
					}
					return result;
				}
				return null;
			}
		};
		return query(sql, resultSetReader, values);
	}

	@Override
	public final BigDecimal queryForBigDecimal(String sql, Object... values) throws OrmException, OrmNotUniqueResultException {
		IResultSetReader resultSetReader = new IResultSetReader() {

			@Override
			public BigDecimal read(ResultSet resultSet) throws SQLException {
				if ( resultSet.next() ) {
					BigDecimal result = resultSet.getBigDecimal(1) ;
					if (resultSet.next()) {
						throw new OrmNotUniqueResultException("The query execution returned a number of rows higher than 1");
					}
					return result;
				}
				return null;
			}
		};
		return query(sql, resultSetReader, values);
	}

	@Override
	public final Object[] queryForArray(String sql, Object... values) throws OrmException, OrmNotUniqueResultException {
		IResultSetReader resultSetReader = new IResultSetReader() {

			@Override
			public Object[] read(ResultSet resultSet) throws SQLException {
				int columnNumber = resultSet.getMetaData().getColumnCount();
				if ( resultSet.next() ) {
					Object[] result = new Object[columnNumber];
					for (int i=0 ; i queryForList(String sql, Object... values) throws OrmException {
		IResultSetReader> resultSetReader = new IResultSetReader>() {

			@Override
			public List read(ResultSet resultSet) throws SQLException {
				int columnNumber = resultSet.getMetaData().getColumnCount();
				List resultList = new ArrayList();
				while ( resultSet.next() ) {
					Object[] objectArray = new Object[columnNumber];
					for (int i=0 ; i T query(String sql, IResultSetReader rse, Object... args) throws OrmException {
		SqlSelectQuery query = new SqlSelectQuery(sql, args, getMaxRows(), getQueryTimeout());
		return sqlPerformerTemplate.query(query, rse);
	}

	@Override
	public int update(String sql, Object... args) throws OrmException {
		return sqlPerformerTemplate.update(sql, getQueryTimeout(), args);
	}

	@Override
	public int update(String sql, IGeneratedKeyReader generatedKeyReader, Object... args) throws OrmException {
		return sqlPerformerTemplate.update(sql, getQueryTimeout(), generatedKeyReader, args);
	}

	@Override
	public int[] batchUpdate(List sqls) throws OrmException {
		return sqlPerformerTemplate.batchUpdate(sqls, getQueryTimeout());
	}

	@Override
	public int[] batchUpdate(String sql, List args) throws OrmException {
		return sqlPerformerTemplate.batchUpdate(sql, args, getQueryTimeout());
	}

	@Override
	public int[] batchUpdate(String sql, IPreparedStatementCreator psc) throws OrmException {
		return sqlPerformerTemplate.batchUpdate(sql, psc, getQueryTimeout());
	}
	
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy