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

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

There is a newer version: 6.1.0
Show newest version
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.EntityForAggregate_Delete;
import info.archinnov.achilles.generated.dsl.EntityForAggregate_Select;
import info.archinnov.achilles.generated.dsl.EntityForAggregate_Update;
import info.archinnov.achilles.generated.meta.entity.EntityForAggregate_AchillesMeta;
import info.archinnov.achilles.internals.dsl.crud.DeleteByPartitionWithOptions;
import info.archinnov.achilles.internals.dsl.crud.DeleteWithOptions;
import info.archinnov.achilles.internals.dsl.crud.FindWithOptions;
import info.archinnov.achilles.internals.dsl.crud.InsertJSONWithOptions;
import info.archinnov.achilles.internals.dsl.crud.InsertWithOptions;
import info.archinnov.achilles.internals.dsl.crud.UpdateWithOptions;
import info.archinnov.achilles.internals.dsl.raw.NativeQuery;
import info.archinnov.achilles.internals.dsl.raw.TypedQuery;
import info.archinnov.achilles.internals.entities.EntityForAggregate;
import info.archinnov.achilles.internals.options.CassandraOptions;
import info.archinnov.achilles.internals.runtime.AbstractManager;
import info.archinnov.achilles.internals.runtime.RuntimeEngine;
import info.archinnov.achilles.type.SchemaNameProvider;
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.String;
import java.util.ArrayList;
import java.util.List;
import java.util.Optional;

public final class EntityForAggregate_Manager extends AbstractManager {
  public final EntityForAggregate_AchillesMeta meta;

  public EntityForAggregate_Manager(final Class entityClass, final EntityForAggregate_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 EntityForAggregate_CRUD crud() { return new EntityForAggregate_CRUD(); } /** * Provide DSL methods:
*
    *
  • SELECT
  • *
  • ITERATION ON SELECT
  • *
  • UPDATE
  • *
  • DELETE
  • *
*/ public final EntityForAggregate_DSL dsl() { return new EntityForAggregate_DSL(); } /** * Provide Raw query methods:
*
    *
  • Typed Queries (for SELECT only)
  • *
  • Native Queries (for any kind of statement)
  • *
*/ public final EntityForAggregate_RAW_QUERY raw() { return new EntityForAggregate_RAW_QUERY(); } public final class EntityForAggregate_CRUD { private Optional cassandraOptions = Optional.empty(); ; public EntityForAggregate_Manager.EntityForAggregate_CRUD withSchemaNameProvider(final SchemaNameProvider schemaNameProvider) { Validator.validateNotNull(schemaNameProvider,"The provided schemaNameProvider should not be null"); this.cassandraOptions = Optional.of(CassandraOptions.withSchemaNameProvider(schemaNameProvider)); return this; } /** * Find an entity by its complete primary key@param partition partition key 'partition'@param clustering clustering column 'clustering'@return FindWithOptions */ public FindWithOptions findById(final Long partition, final Integer clustering) { List keys = new ArrayList<>(); List encodedKeys = new ArrayList<>(); Validator.validateNotNull(partition, "Partition key '%s' should not be null", "partition"); keys.add(partition); encodedKeys.add(EntityForAggregate_AchillesMeta.partition.encodeFromJava(partition, cassandraOptions)); Validator.validateNotNull(clustering, "Partition key '%s' should not be null", "clustering"); keys.add(clustering); encodedKeys.add(EntityForAggregate_AchillesMeta.clustering.encodeFromJava(clustering, cassandraOptions)); final Object[] primaryKeyValues = keys.toArray(); final Object[] encodedPrimaryKeyValues = encodedKeys.toArray(); return new FindWithOptions(entityClass, meta, rte, primaryKeyValues, encodedPrimaryKeyValues, cassandraOptions); } /** * 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 EntityForAggregate to be delete@return DeleteWithOptions */ public DeleteWithOptions delete(final EntityForAggregate instance) { return deleteInternal(instance, cassandraOptions); } /** * Delete an entity using its complete primary key@param partition partition key 'partition'@param clustering clustering column 'clustering'@return DeleteWithOptions */ public DeleteWithOptions deleteById(final Long partition, final Integer clustering) { List keys = new ArrayList<>(); List encodedKeys = new ArrayList<>(); Validator.validateNotNull(partition, "Partition key '%s' should not be null", "partition"); keys.add(partition); encodedKeys.add(EntityForAggregate_AchillesMeta.partition.encodeFromJava(partition, cassandraOptions)); Validator.validateNotNull(clustering, "Partition key '%s' should not be null", "clustering"); keys.add(clustering); encodedKeys.add(EntityForAggregate_AchillesMeta.clustering.encodeFromJava(clustering, cassandraOptions)); final Object[] partitionKeysValues = keys.toArray(); final Object[] encodedPartitionKeyValues = encodedKeys.toArray(); return new DeleteWithOptions(entityClass, meta, rte, partitionKeysValues, encodedPartitionKeyValues, Optional.empty(), cassandraOptions); } /** * Insert this entity * * @param instance an instance of EntityForAggregate * @return InsertWithOptions */ public final InsertWithOptions insert(final EntityForAggregate instance) { return insertInternal(instance, false, cassandraOptions); } /** * Update the cassandra table with NOT NULL fields extracted from this entity * * @param instance an instance of EntityForAggregate * @return InsertWithOptions */ public final UpdateWithOptions update(final EntityForAggregate instance) { return updateInternal(instance, false, cassandraOptions); } /** * Delete a whole partition using the partition key@param partition partition key 'partition'@return DeleteByPartitionWithOptions */ public DeleteByPartitionWithOptions deleteByPartitionKeys(final Long partition) { List keys = new ArrayList<>(); List encodedKeys = new ArrayList<>(); Validator.validateNotNull(partition, "Partition key '%s' should not be null", "partition"); keys.add(partition); encodedKeys.add(EntityForAggregate_AchillesMeta.partition.encodeFromJava(partition, cassandraOptions)); final Object[] partitionKeys = keys.toArray(); final Object[] encodedPartitionKeys = encodedKeys.toArray(); return new DeleteByPartitionWithOptions(meta, rte, partitionKeys, encodedPartitionKeys, cassandraOptions); } /** * Insert using a JSON payload * * @json the JSON string representing an instance of EntityForAggregate * @return InsertJSONWithOptions */ public final InsertJSONWithOptions insertJSON(final String json) { return insertJSONInternal(json, cassandraOptions); } } public final class EntityForAggregate_DSL { /** * Generate a SELECT statement@return EntityForAggregate_Select */ public final EntityForAggregate_Select select() { return new EntityForAggregate_Select(rte, meta); } /** * Generate a DELETE statement@return EntityForAggregate_Delete */ public final EntityForAggregate_Delete delete() { return new EntityForAggregate_Delete(rte, meta); } /** * Generate an UPDATE statement@return EntityForAggregate_Update */ public final EntityForAggregate_Update update() { return new EntityForAggregate_Update(rte, meta); } } public final class EntityForAggregate_RAW_QUERY { /** * Execute the bound statement and map the result back into an instance of EntityForAggregate
* 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 EntityForAggregate
* 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 EntityForAggregate
* 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); } } }