Package br.com.objectos.comuns.relational.jdbc

Source Code of br.com.objectos.comuns.relational.jdbc.JdbcSQLBuilderExecGuice$IteratorImpl

/*
* Copyright 2011 Objectos, Fábrica de Software LTDA.
*
* 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 br.com.objectos.comuns.relational.jdbc;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Iterator;
import java.util.List;

import br.com.objectos.comuns.relational.search.HasElements;
import br.com.objectos.comuns.relational.search.Page;
import br.com.objectos.comuns.relational.search.ResultSetLoader;
import br.com.objectos.comuns.relational.search.SQLBuilder;
import br.com.objectos.comuns.relational.search.SimplePage;

import com.google.common.collect.ImmutableList;
import com.google.common.collect.Iterators;
import com.google.inject.Inject;

/**
* @author marcio.endo@objectos.com.br (Marcio Endo)
*/
class JdbcSQLBuilderExecGuice implements JdbcSQLBuilderExec {

  private final SQLProvider<Connection> connections;

  @Inject
  public JdbcSQLBuilderExecGuice(SQLProvider<Connection> connections) {
    this.connections = connections;
  }

  @Override
  public <T> Iterator<T> iterate(SQLBuilder sql) {
    return new IteratorImpl<T>(this, sql);
  }

  @Override
  public <T> List<T> list(SQLBuilder sql) {
    return list0(sql);
  }

  @Override
  public <T> List<T> listPage(SQLBuilder sql, Page page) {
    HasElements limitFor = sql.limitFor(page);
    return list0(limitFor);
  }

  @SuppressWarnings("unchecked")
  @Override
  public <T> T single(SQLBuilder sql) {
    T result = null;

    Connection connection = null;
    SelectConfigure configure = null;
    PreparedStatement stmt = null;
    ResultSet rs = null;

    try {

      connection = connections.get();
      configure = new SelectConfigure(sql);
      stmt = configure.prepare(connection);
      ResultSetLoader<?> loader = configure.getLoader();
      rs = stmt.executeQuery();
      result = (T) (rs.next() ? loader.load(rs) : null);

    } catch (SQLException e) {
      throw new SQLRuntimeException(e);
    } finally {
      Jdbc.close(connection);
      Jdbc.close(stmt);
      Jdbc.close(rs);
    }

    return result;
  }

  private <T> List<T> list0(HasElements sql) {
    List<T> result = null;

    Connection connection = null;
    SelectConfigure configure = null;
    PreparedStatement stmt = null;
    ResultSet rs = null;

    try {

      connection = connections.get();
      configure = new SelectConfigure(sql);
      stmt = configure.prepare(connection);
      ResultSetLoader<?> loader = configure.getLoader();
      rs = stmt.executeQuery();
      Iterator<ResultSet> iterator = new ResultSetIterator(rs);
      Iterator<T> loaded = Iterators.transform(iterator, new LoaderFunction<T>(loader));
      result = ImmutableList.copyOf(loaded);

    } catch (SQLException e) {
      String msg = configure != null ? configure.toString() : null;
      throw new SQLRuntimeException(msg, e);
    } finally {
      Jdbc.close(connection);
      Jdbc.close(stmt);
      Jdbc.close(rs);
    }

    return result;
  }

  private static class IteratorImpl<E> implements Iterator<E> {

    private final JdbcSQLBuilderExec exec;

    private final SQLBuilder sql;

    private final int iterationLength = 1000;

    private int page = 0;

    private Iterator<E> iterator;

    public IteratorImpl(JdbcSQLBuilderExec exec, SQLBuilder sql) {
      this.exec = exec;
      this.sql = sql;
    }

    @Override
    public boolean hasNext() {
      if (iterator == null || !iterator.hasNext()) {
        updateIterator();
      }
      return iterator.hasNext();
    }

    @Override
    public E next() {
      return iterator.next();
    }

    @Override
    public void remove() {
      throw new UnsupportedOperationException();
    }

    private void updateIterator() {
      List<E> itens = getNextPage();
      iterator = itens.iterator();
    }

    private List<E> getNextPage() {
      int firstResult = firstResult();

      SimplePage paginator = SimplePage.build() //
          .startAt(firstResult) //
          .withLengthOf(iterationLength) //
          .get();

      page++;

      return exec.listPage(sql, paginator);
    }

    private int firstResult() {
      return page * iterationLength;
    }

  }

}
TOP

Related Classes of br.com.objectos.comuns.relational.jdbc.JdbcSQLBuilderExecGuice$IteratorImpl

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.