influxdata/influxdb-java

View on GitHub
src/main/java/org/influxdb/querybuilder/SelectSubQueryImpl.java

Summary

Maintainability
A
0 mins
Test Coverage
package org.influxdb.querybuilder;

import java.util.List;
import org.influxdb.querybuilder.clauses.Clause;
import org.influxdb.querybuilder.clauses.FromClause;

public class SelectSubQueryImpl<T extends WithSubquery> extends SubQuery<T>
    implements SelectWithSubquery {

  private SelectCoreImpl<WhereSubQueryImpl<SelectSubQueryImpl<T>, T>> selectCore;
  private WhereSubQueryImpl<SelectSubQueryImpl<T>, T> whereSubQuery;

  SelectSubQueryImpl(
      final FromClause fromClause, final List<Object> columns, final boolean isDistinct) {
    whereSubQuery = new WhereSubQueryImpl<>(this, new WhereCoreImpl<>(this));
    this.selectCore = new SelectCoreImpl<>(fromClause, columns, isDistinct, whereSubQuery);
  }

  SelectSubQueryImpl(final List<Object> columns, final boolean isDistinct) {
    whereSubQuery = new WhereSubQueryImpl<>(this, new WhereCoreImpl<>(this));
    this.selectCore = new SelectCoreImpl<>(columns, isDistinct, whereSubQuery);
  }

  @Override
  public WhereSubQueryImpl<SelectSubQueryImpl<T>, T> where() {
    return selectCore.where();
  }

  @Override
  public WhereSubQueryImpl<SelectSubQueryImpl<T>, T> where(final Clause clause) {
    return selectCore.where(clause);
  }

  @Override
  public WhereSubQueryImpl<SelectSubQueryImpl<T>, T> where(final String text) {
    return selectCore.where(text);
  }

  @Override
  public SelectSubQueryImpl<T> orderBy(final Ordering ordering) {
    selectCore.orderBy(ordering);
    return this;
  }

  @Override
  public SelectSubQueryImpl<T> groupBy(final Object... columns) {
    selectCore.groupBy(columns);
    return this;
  }

  @Override
  public SelectSubQueryImpl<T> fill(final Number value) {
    selectCore.fill(value);
    return this;
  }

  @Override
  public SelectSubQueryImpl<T> fill(final String value) {
    selectCore.fill(value);
    return this;
  }

  @Override
  public SelectSubQueryImpl<T> limit(final int limit) {
    selectCore.limit(limit);
    return this;
  }

  @Override
  public SelectSubQueryImpl<T> limit(final int limit, final long offSet) {
    selectCore.limit(limit, offSet);
    return this;
  }

  @Override
  public SelectSubQueryImpl<T> sLimit(final int sLimit) {
    selectCore.sLimit(sLimit);
    return this;
  }

  @Override
  public SelectSubQueryImpl<T> sLimit(final int sLimit, final long sOffSet) {
    selectCore.sLimit(sLimit, sOffSet);
    return this;
  }

  @Override
  public SelectSubQueryImpl<T> tz(final String timezone) {
    selectCore.tz(timezone);
    return this;
  }

  @Override
  public StringBuilder buildQueryString() {
    return selectCore.buildQueryString(new StringBuilder());
  }

  @Override
  public StringBuilder buildQueryString(final StringBuilder stringBuilder) {
    return selectCore.buildQueryString(stringBuilder);
  }

  @Override
  public void setSubQuery(final QueryStringBuilder query) {
    selectCore.setSubQuery(query);
  }

  @Override
  void setParent(final T parent) {
    whereSubQuery.setParent(parent);
    super.setParent(parent);
  }
}