info.archinnov.achilles.query.slice.AsyncIterateDSL Maven / Gradle / Ivy
/*
* Copyright (C) 2012-2014 DuyHai DOAN
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package info.archinnov.achilles.query.slice;
import info.archinnov.achilles.internal.metadata.holder.EntityMeta;
import info.archinnov.achilles.internal.persistence.operations.SliceQueryExecutor;
import static info.archinnov.achilles.query.slice.SliceQueryProperties.SliceType;
public class AsyncIterateDSL {
private final SliceQueryExecutor sliceQueryExecutor;
private final Class entityClass;
private final EntityMeta meta;
private final SliceType sliceType;
protected AsyncIterateDSL(SliceQueryExecutor sliceQueryExecutor, Class entityClass, EntityMeta meta, SliceType sliceType) {
this.sliceQueryExecutor = sliceQueryExecutor;
this.entityClass = entityClass;
this.meta = meta;
this.sliceType = sliceType;
}
/**
*
* Start the Iterate DSL with provided partition components
*
*
*
* asyncManager.sliceQuery(ArticleRating.class)
* .forIteration()
* .withPartitionComponents(articleId)
*
*
*
* Generated CQL query:
*
*
* SELECT * FROM article_rating WHERE article_id=...
*
* @return slice DSL
*/
public AsyncIterateFromPartition withPartitionComponents(Object... partitionKeyComponents) {
AsyncIterateFromPartition iterateFromPartitionKey = new AsyncIterateFromPartition<>(sliceQueryExecutor, entityClass, meta, sliceType);
iterateFromPartitionKey.withPartitionComponentsInternal(partitionKeyComponents);
return iterateFromPartitionKey;
}
/**
*
* Start the Iterate DSL with provided partition components IN
*
*
*
* asyncManager.sliceQuery(MessageEntity.class)
* .forIteration()
* .withPartitionComponents(10L)
* .andPartitionComponentsIN(2013, 2014)
*
*
*
* Generated CQL query:
*
*
* SELECT * FROM messages WHERE user_id=10 AND year IN (2013,2014)
*
* @return slice DSL
*/
public AsyncIterateWithPartition withPartitionComponentsIN(Object... partitionKeyComponents) {
AsyncIterateWithPartition iterateWithPartition = new AsyncIterateWithPartition<>(sliceQueryExecutor, entityClass, meta, sliceType);
iterateWithPartition.withPartitionComponentsINInternal(partitionKeyComponents);
return iterateWithPartition;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy