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

info.archinnov.achilles.generated.manager.EntityWithStaticCounterColumn_Manager Maven / Gradle / Ivy

package info.archinnov.achilles.generated.manager;

import com.datastax.driver.core.BoundStatement;
import com.datastax.driver.core.PreparedStatement;
import com.datastax.driver.core.RegularStatement;
import info.archinnov.achilles.generated.dsl.EntityWithStaticCounterColumn_Delete;
import info.archinnov.achilles.generated.dsl.EntityWithStaticCounterColumn_DeleteStatic;
import info.archinnov.achilles.generated.dsl.EntityWithStaticCounterColumn_Select;
import info.archinnov.achilles.generated.dsl.EntityWithStaticCounterColumn_Update;
import info.archinnov.achilles.generated.dsl.EntityWithStaticCounterColumn_UpdateStatic;
import info.archinnov.achilles.generated.meta.entity.EntityWithStaticCounterColumn_AchillesMeta;
import info.archinnov.achilles.internals.entities.EntityWithStaticCounterColumn;
import info.archinnov.achilles.internals.query.crud.DeleteByPartitionWithOptions;
import info.archinnov.achilles.internals.query.crud.DeleteWithOptions;
import info.archinnov.achilles.internals.query.crud.FindWithOptions;
import info.archinnov.achilles.internals.query.raw.NativeQuery;
import info.archinnov.achilles.internals.query.typed.TypedQuery;
import info.archinnov.achilles.internals.runtime.AbstractManager;
import info.archinnov.achilles.internals.runtime.RuntimeEngine;
import info.archinnov.achilles.validation.Validator;
import java.lang.Class;
import java.lang.Long;
import java.lang.Object;
import java.util.ArrayList;
import java.util.List;
import java.util.Optional;
import java.util.UUID;

public final class EntityWithStaticCounterColumn_Manager extends AbstractManager {
  public final EntityWithStaticCounterColumn_AchillesMeta meta;

  public EntityWithStaticCounterColumn_Manager(final Class entityClass, final EntityWithStaticCounterColumn_AchillesMeta meta, final RuntimeEngine rte) {
    super(entityClass, meta, rte);
    this.meta = meta;
  }

  /**
   * Provide CRUD operations: 
*
    *
  • FIND BY ID
  • *
  • INSERT
  • *
  • INSERT STATIC
  • *
  • INSERT IF NOT EXISTS
  • *
  • DELETE BY ID
  • *
  • DELETE BY ID IF NOT EXISTS
  • *
  • DELETE BY PARTITION
  • *
*/ public final EntityWithStaticCounterColumn_CRUD crud() { return new EntityWithStaticCounterColumn_CRUD(); } /** * Provide DSL methods:
*
    *
  • SELECT
  • *
  • ITERATION ON SELECT
  • *
  • UPDATE
  • *
  • DELETE
  • *
*/ public final EntityWithStaticCounterColumn_DSL dsl() { return new EntityWithStaticCounterColumn_DSL(); } /** * Provide QUERY methods:
*
    *
  • Typed Queries (for SELECT only)
  • *
  • Native Queries (for any kind of statement)
  • *
*/ public final EntityWithStaticCounterColumn_QUERY query() { return new EntityWithStaticCounterColumn_QUERY(); } public final class EntityWithStaticCounterColumn_CRUD { /** * Find an entity by its complete primary key@param id partition key 'id'@param uuid clustering column 'uuid'@return FindWithOptions */ public FindWithOptions findById(final Long id, final UUID uuid) { List keys = new ArrayList<>(); List encodedKeys = new ArrayList<>(); Validator.validateNotNull(id, "Partition key '%s' should not be null", "id"); keys.add(id); encodedKeys.add(EntityWithStaticCounterColumn_AchillesMeta.id.encodeFromJava(id)); Validator.validateNotNull(uuid, "Partition key '%s' should not be null", "uuid"); keys.add(uuid); encodedKeys.add(EntityWithStaticCounterColumn_AchillesMeta.uuid.encodeFromJava(uuid)); final Object[] primaryKeyValues = keys.toArray(); final Object[] encodedPrimaryKeyValues = encodedKeys.toArray(); return new FindWithOptions(entityClass, meta, rte, primaryKeyValues, encodedPrimaryKeyValues); } /** * Delete an entity instance by extracting its primary keyRemark: Achilles will throw an exception if any column being part of the primary key is NULL@param an instance of EntityWithStaticCounterColumn to be delete@return DeleteWithOptions */ public DeleteWithOptions delete(final EntityWithStaticCounterColumn instance) { return deleteInternal(instance); } /** * Delete an entity using its complete primary key@param id partition key 'id'@param uuid clustering column 'uuid'@return DeleteWithOptions */ public DeleteWithOptions deleteById(final Long id, final UUID uuid) { List keys = new ArrayList<>(); List encodedKeys = new ArrayList<>(); Validator.validateNotNull(id, "Partition key '%s' should not be null", "id"); keys.add(id); encodedKeys.add(EntityWithStaticCounterColumn_AchillesMeta.id.encodeFromJava(id)); Validator.validateNotNull(uuid, "Partition key '%s' should not be null", "uuid"); keys.add(uuid); encodedKeys.add(EntityWithStaticCounterColumn_AchillesMeta.uuid.encodeFromJava(uuid)); final Object[] partitionKeysValues = keys.toArray(); final Object[] encodedPartitionKeyValues = encodedKeys.toArray(); return new DeleteWithOptions(entityClass, meta, rte, partitionKeysValues, encodedPartitionKeyValues, Optional.empty()); } /** * Delete a whole partition using the partition key@param id partition key 'id'@return DeleteByPartitionWithOptions */ public DeleteByPartitionWithOptions deleteByPartitionKeys(final Long id) { List keys = new ArrayList<>(); List encodedKeys = new ArrayList<>(); Validator.validateNotNull(id, "Partition key '%s' should not be null", "id"); keys.add(id); encodedKeys.add(EntityWithStaticCounterColumn_AchillesMeta.id.encodeFromJava(id)); final Object[] partitionKeys = keys.toArray(); final Object[] encodedPartitionKeys = encodedKeys.toArray(); return new DeleteByPartitionWithOptions(meta, rte, partitionKeys, encodedPartitionKeys); } } public final class EntityWithStaticCounterColumn_DSL { /** * Generate a SELECT statement@return EntityWithStaticCounterColumn_Select */ public final EntityWithStaticCounterColumn_Select select() { return new EntityWithStaticCounterColumn_Select(rte, meta); } /** * Generate a DELETE statement@return EntityWithStaticCounterColumn_Delete */ public final EntityWithStaticCounterColumn_Delete delete() { return new EntityWithStaticCounterColumn_Delete(rte, meta); } /** * Generate an UPDATE statement@return EntityWithStaticCounterColumn_Update */ public final EntityWithStaticCounterColumn_Update update() { return new EntityWithStaticCounterColumn_Update(rte, meta); } /** * Generate a DELETE statement for static columns only(requiring only partition key(s))@return EntityWithStaticCounterColumn_DeleteStatic */ public final EntityWithStaticCounterColumn_DeleteStatic deleteStatic() { return new EntityWithStaticCounterColumn_DeleteStatic(rte, meta); } /** * Generate an UPDATE statement for static columns only(requiring only partition key(s))@return EntityWithStaticCounterColumn_UpdateStatic */ public final EntityWithStaticCounterColumn_UpdateStatic updateStatic() { return new EntityWithStaticCounterColumn_UpdateStatic(rte, meta); } } public final class EntityWithStaticCounterColumn_QUERY { /** * Execute the bound statement and map the result back into an instance of EntityWithStaticCounterColumn
* Remark: the bound statement should be a SELECT statement@param boundStatement a bound statement@return TypedQuery */ public final TypedQuery typedQueryForSelect(BoundStatement boundStatement) { return typedQueryForSelectInternal(boundStatement); } /** * Execute the prepared statement and map the result back into an instance of EntityWithStaticCounterColumn
* Remark: the prepared statement should be a SELECT statement@param preparedStatement a prepared statement@return TypedQuery */ public final TypedQuery typedQueryForSelect(PreparedStatement preparedStatement, Object... encodedBoundValues) { return typedQueryForSelectInternal(preparedStatement, encodedBoundValues); } /** * Execute the regular statement and map the result back into an instance of EntityWithStaticCounterColumn
* Remark: the regular statement should be a SELECT statement@param regularStatement a regular statement@return TypedQuery */ public final TypedQuery typedQueryForSelect(RegularStatement regularStatement, Object... encodedBoundValues) { return typedQueryForSelectInternal(regularStatement, encodedBoundValues); } /** * Execute the native bound statement@param boundStatement a bound statement@return NativeQuery */ public final NativeQuery nativeQuery(BoundStatement boundStatement) { return nativeQueryInternal(boundStatement); } /** * Execute the native prepared statement@param preparedStatement a prepared statement@return NativeQuery */ public final NativeQuery nativeQuery(PreparedStatement preparedStatement, Object... encodedBoundValues) { return nativeQueryInternal(preparedStatement, encodedBoundValues); } /** * Execute the native regular statement@param regularStatement a regular statement@return NativeQuery */ public final NativeQuery nativeQuery(RegularStatement regularStatement, Object... encodedBoundValues) { return nativeQueryInternal(regularStatement, encodedBoundValues); } } }