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

ai.grakn.engine.task.postprocessing.CountStorage Maven / Gradle / Ivy

There is a newer version: 1.4.3
Show newest version
/*
 * Grakn - A Distributed Semantic Database
 * Copyright (C) 2016-2018 Grakn Labs Limited
 *
 * Grakn is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * Grakn is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with Grakn. If not, see .
 */

package ai.grakn.engine.task.postprocessing;

import ai.grakn.Keyspace;
import ai.grakn.concept.ConceptId;

/**
 *
 * 

* Stores a cache of counts so that we can know which {@link ai.grakn.concept.Type}s to shard when they have too many * instances. *

* * @author Ganeshwara Herawan Hananda */ public interface CountStorage { /** * Adjusts the count for a specific concept. * * @param keyspace * @param conceptId * @param incrementBy the number to adjust the key by * @return the final value after being adjusted */ long incrementInstanceCount(Keyspace keyspace, ConceptId conceptId, long incrementBy); /** * Adjusts the shard count for a specific concept. * * @param keyspace * @param conceptId * @param incrementBy the number to adjust the key by * @return the final value after being adjusted */ long incrementShardCount(Keyspace keyspace, ConceptId conceptId, long incrementBy); /** * Get the instance count for a specific concept. * * @param keyspace * @param conceptId * @return the instance count */ long getInstanceCount(Keyspace keyspace, ConceptId conceptId); /** * Get the shard count for a specific concept. * * @param keyspace * @param conceptId * @return the shard count */ long getShardCount(Keyspace keyspace, ConceptId conceptId); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy