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

br.com.objectos.way.sql.AbstractSimpleSelectWhere20 Maven / Gradle / Ivy

There is a newer version: 0.4.1
Show newest version
package br.com.objectos.way.sql;

import br.com.objectos.way.db.Condition;
import br.com.objectos.way.db.Dialect;
import br.com.objectos.way.db.IntTypeColumn;
import br.com.objectos.way.db.LocalDateTypeColumn;
import br.com.objectos.way.db.Order;
import br.com.objectos.way.db.Orderable;
import br.com.objectos.way.db.ParameterBinder;
import br.com.objectos.way.db.SelectBuilder;
import br.com.objectos.way.db.Selectable;
import br.com.objectos.way.db.StringTypeColumn;
import javax.annotation.Generated;

@Generated("br.com.objectos.way.sql.BootProcessor")
abstract class AbstractSimpleSelectWhere20 extends SelectNode> implements SimpleSelectWhere> {
  private Condition condition;

  public AbstractSimpleSelectWhere20(SelectNode> previous) {
    super(previous);
  }

  @Override
  public  SimpleSelectWhere20Int and(X column) {
    setCondition();
    return new SimpleSelectWhere20Int<>(this, Keyword.AND, column);
  }

  @Override
  public  SimpleSelectWhere20LocalDate and(X column) {
    setCondition();
    return new SimpleSelectWhere20LocalDate<>(this, Keyword.AND, column);
  }

  @Override
  public  SimpleSelectWhere20String and(X column) {
    setCondition();
    return new SimpleSelectWhere20String<>(this, Keyword.AND, column);
  }

  @Override
  public SimpleSelectQuery20 compile(Dialect dialect) {
    setCondition();
    return new SimpleSelectQuery20<>(dialect, this);
  }

  @Override
  public SimpleSelectOrderBy20 orderBy(Orderable o1) {
    return orderBy(o1.asc());
  }

  @Override
  public SimpleSelectOrderBy20 orderBy(Order o1) {
    return orderBy0(o1);
  }

  @Override
  ParameterBinder bind0(ParameterBinder binder) {
    if (condition != null) {
      condition.bind(binder);
    }
    return binder;
  }

  abstract Condition condition();

  @Override
  SelectBuilder write0(SelectBuilder sql) {
    return condition != null ? sql.where(condition) : sql;
  }

  private SimpleSelectOrderBy20 orderBy0(Order... columns) {
    setCondition();
    return new SimpleSelectOrderBy20<>(this, columns);
  }

  private void setCondition() {
    condition = condition();
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy