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

info.archinnov.achilles.generated.dsl.EntityWithComplexTuple_Delete Maven / Gradle / Ivy

There is a newer version: 4.2.3
Show newest version
package info.archinnov.achilles.generated.dsl;

import com.datastax.driver.core.querybuilder.Delete;
import com.datastax.driver.core.querybuilder.NotEq;
import com.datastax.driver.core.querybuilder.QueryBuilder;
import info.archinnov.achilles.generated.meta.entity.EntityWithComplexTuple_AchillesMeta;
import info.archinnov.achilles.internals.entities.EntityWithComplexTuple;
import info.archinnov.achilles.internals.metamodel.AbstractEntityProperty;
import info.archinnov.achilles.internals.options.Options;
import info.archinnov.achilles.internals.query.dsl.delete.AbstractDelete;
import info.archinnov.achilles.internals.query.dsl.delete.AbstractDeleteColumns;
import info.archinnov.achilles.internals.query.dsl.delete.AbstractDeleteEnd;
import info.archinnov.achilles.internals.query.dsl.delete.AbstractDeleteFrom;
import info.archinnov.achilles.internals.query.dsl.delete.AbstractDeleteWherePartition;
import info.archinnov.achilles.internals.runtime.RuntimeEngine;
import info.archinnov.achilles.type.SchemaNameProvider;
import info.archinnov.achilles.type.tuples.Tuple2;
import info.archinnov.achilles.validation.Validator;
import java.lang.Class;
import java.lang.Integer;
import java.lang.Long;
import java.lang.Object;
import java.lang.Override;
import java.lang.String;
import java.lang.SuppressWarnings;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
import org.apache.commons.lang3.ArrayUtils;

public final class EntityWithComplexTuple_Delete extends AbstractDelete {
  protected final EntityWithComplexTuple_AchillesMeta meta;

  protected final Class entityClass = EntityWithComplexTuple.class;

  public EntityWithComplexTuple_Delete(RuntimeEngine rte, EntityWithComplexTuple_AchillesMeta meta) {
    super(rte);
    this.meta = meta;
  }

  /**
   * Generate DELETE tuple ... */
  public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteColumns tuple() {
    delete.column("tuple");
    return new EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteColumns(delete);
  }

  /**
   * Generate ... * FROM ... */
  public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteFrom allColumns_FromBaseTable() {
    final Delete.Where where = delete.all().from(meta.getKeyspace().orElse("unknown_keyspace_for_" + meta.entityClass.getCanonicalName()), meta.getTableOrViewName()).where();
    return new EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteFrom(where);
  }

  /**
   * Generate ... * FROM ... using the given SchemaNameProvider */
  public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteFrom allColumns_From(final SchemaNameProvider schemaNameProvider) {
    final String currentKeyspace = lookupKeyspace(schemaNameProvider, meta.entityClass);
    final String currentTable = lookupTable(schemaNameProvider, meta.entityClass);
    final Delete.Where where = delete.all().from(currentKeyspace, currentTable).where();
    return new EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteFrom(where);
  }

  public class EntityWithComplexTuple_DeleteColumns extends AbstractDeleteColumns {
    EntityWithComplexTuple_DeleteColumns(Delete.Selection deleteColumns) {
      super(deleteColumns);
    }

    /**
     * Generate DELETE tuple ... */
    public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteColumns tuple() {
      delete.column("tuple");
      return this;
    }

    /**
     * Generate a ... FROM xxx ...  */
    public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteFrom fromBaseTable() {
      final Delete.Where where = deleteColumns.from(meta.getKeyspace().orElse("unknown_keyspace_for_" + meta.entityClass.getCanonicalName()), meta.getTableOrViewName()).where();
      return new EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteFrom(where);
    }

    /**
     * Generate a ... FROM xxx ... using the given SchemaNameProvider */
    public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteFrom from(final SchemaNameProvider schemaNameProvider) {
      final String currentKeyspace = lookupKeyspace(schemaNameProvider, meta.entityClass);
      final String currentTable = lookupTable(schemaNameProvider, meta.entityClass);
      final Delete.Where where = deleteColumns.from(currentKeyspace, currentTable).where();
      return new EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteFrom(where);
    }
  }

  public class EntityWithComplexTuple_DeleteFrom extends AbstractDeleteFrom {
    EntityWithComplexTuple_DeleteFrom(Delete.Where where) {
      super(where);
    }

    public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteWhere_Id where() {
      return new EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteWhere_Id(where);
    }
  }

  public final class EntityWithComplexTuple_DeleteWhere_Id extends AbstractDeleteWherePartition {
    public EntityWithComplexTuple_DeleteWhere_Id(Delete.Where where) {
      super(where);
    }

    /**
     * Generate a SELECT ... FROM ... WHERE ... id = ? */
    @SuppressWarnings("static-access")
    public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteEnd id_Eq(Long id) {
      where.and(QueryBuilder.eq("id", QueryBuilder.bindMarker("id_Eq")));
      boundValues.add(id);
      encodedValues.add(meta.id.encodeFromJava(id));
      return new EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteEnd(where);
    }

    /**
     * Generate a SELECT ... FROM ... WHERE ... id IN ? */
    @SuppressWarnings("static-access")
    public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteEnd id_IN(Long... id) {
      Validator.validateTrue(ArrayUtils.isNotEmpty(id), "Varargs for field '%s' should not be null/empty", "id");
      where.and(QueryBuilder.in("id",QueryBuilder.bindMarker("id")));
      final List varargs = Arrays.asList((Object[])id);
      final List encodedVarargs = Arrays.stream((Long[])id).map(x -> meta.id.encodeFromJava(x)).collect(Collectors.toList());
      boundValues.add(varargs);
      encodedValues.add(encodedVarargs);
      return new EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteEnd(where);
    }
  }

  public final class EntityWithComplexTuple_DeleteEnd extends AbstractDeleteEnd {
    public EntityWithComplexTuple_DeleteEnd(Delete.Where where) {
      super(where);
    }

    @Override
    protected final Class getEntityClass() {
      return entityClass;
    }

    @Override
    protected final AbstractEntityProperty getMetaInternal() {
      return meta;
    }

    @Override
    protected final RuntimeEngine getRte() {
      return rte;
    }

    @Override
    protected final Options getOptions() {
      return options;
    }

    @Override
    protected final List getBoundValuesInternal() {
      return boundValues;
    }

    @Override
    protected final List getEncodedValuesInternal() {
      return encodedValues;
    }

    @Override
    protected final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteEnd getThis() {
      return this;
    }

    /**
     * Generate an ... IF tuple = ? */
    @SuppressWarnings("static-access")
    public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteEnd ifTuple_Eq(final Tuple2>> tuple) {
      boundValues.add(tuple);
      encodedValues.add(meta.tuple.encodeFromJava(tuple));
      where.onlyIf(QueryBuilder.eq("tuple", QueryBuilder.bindMarker("tuple")));
      return this;
    }

    /**
     * Generate an ... IF tuple > ? */
    @SuppressWarnings("static-access")
    public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteEnd ifTuple_Gt(final Tuple2>> tuple) {
      boundValues.add(tuple);
      encodedValues.add(meta.tuple.encodeFromJava(tuple));
      where.onlyIf(QueryBuilder.gt("tuple", QueryBuilder.bindMarker("tuple")));
      return this;
    }

    /**
     * Generate an ... IF tuple >= ? */
    @SuppressWarnings("static-access")
    public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteEnd ifTuple_Gte(final Tuple2>> tuple) {
      boundValues.add(tuple);
      encodedValues.add(meta.tuple.encodeFromJava(tuple));
      where.onlyIf(QueryBuilder.gte("tuple", QueryBuilder.bindMarker("tuple")));
      return this;
    }

    /**
     * Generate an ... IF tuple < ? */
    @SuppressWarnings("static-access")
    public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteEnd ifTuple_Lt(final Tuple2>> tuple) {
      boundValues.add(tuple);
      encodedValues.add(meta.tuple.encodeFromJava(tuple));
      where.onlyIf(QueryBuilder.lt("tuple", QueryBuilder.bindMarker("tuple")));
      return this;
    }

    /**
     * Generate an ... IF tuple <= ? */
    @SuppressWarnings("static-access")
    public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteEnd ifTuple_Lte(final Tuple2>> tuple) {
      boundValues.add(tuple);
      encodedValues.add(meta.tuple.encodeFromJava(tuple));
      where.onlyIf(QueryBuilder.lte("tuple", QueryBuilder.bindMarker("tuple")));
      return this;
    }

    /**
     * Generate an  ... IF tuple != ? */
    @SuppressWarnings("static-access")
    public final EntityWithComplexTuple_Delete.EntityWithComplexTuple_DeleteEnd ifTuple_NotEq(final Tuple2>> tuple) {
      boundValues.add(tuple);
      encodedValues.add(meta.tuple.encodeFromJava(tuple));
      where.onlyIf(NotEq.of("tuple", QueryBuilder.bindMarker("tuple")));
      return this;
    }
  }
}