com.google.cloud.datastore.Batch Maven / Gradle / Ivy
Show all versions of google-cloud-datastore Show documentation
/*
* Copyright 2015 Google LLC
*
* 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 com.google.cloud.datastore;
import java.util.List;
import javax.annotation.concurrent.NotThreadSafe;
/**
* An interface to represent a batch of write operations. Any write operation that is applied on a
* batch will only be sent to the Datastore upon {@link #submit}. A usage example:
*
* {@code
* Entity entity1 = datastore.get(key1);
* Batch batch = datastore.newBatch();
* Entity entity2 = Entity.newBuilder(key2).set("name", "John").build();
* entity1 = Entity.newBuilder(entity1).clear().setNull("bla").build();
* Entity entity3 = Entity.newBuilder(key3).set("title", "title").build();
* batch.update(entity1);
* batch.add(entity2, entity3);
* batch.submit();
* }
*
* WARNING: This class maintains an internal state in terms of {@link
* java.util.LinkedHashMap} and {@link java.util.LinkedHashSet} which gets updated on every method
* call performing CRUD operations to record the mutations. Since {@link java.util.LinkedHashMap} is
* not thread safe as per its documentation,
* This class too should not be treated as a thread safe class.
*/
@NotThreadSafe
public interface Batch extends DatastoreBatchWriter {
interface Response {
/** Returns a list of keys generated by a batch. */
List getGeneratedKeys();
}
/**
* {@inheritDoc}
*
* If an entity for {@code entity.getKey()} does not exist, {@code entity} is inserted.
* Otherwise, {@link #submit()} will throw a {@link DatastoreException} with {@link
* DatastoreException#getReason()} equal to {@code "ALREADY_EXISTS"}.
*
* @param entity the entity to be added to the datastore
* @return The entity that was added
* @throws DatastoreException if there was any failure
*/
@Override
Entity add(FullEntity> entity);
/**
* {@inheritDoc}
*
*
If none of entities' keys exist, all entities are inserted. If any of entities' keys already
* exists, {@link #submit()} will throw a {@link DatastoreException} with {@link
* DatastoreException#getReason()} equal to {@code "ALREADY_EXISTS"}. All entities in {@code
* entities} whose key did not exist are inserted.
*
* @param entities entities to be added to the datastore
* @return A list of entities that have been added
* @throws DatastoreException if there was any failure
*/
@Override
List add(FullEntity>... entities);
/**
* Submit the batch to the Datastore.
*
* @return Response of the batch submit operation.
* @throws DatastoreException if there was any failure or if batch is no longer active
*/
Response submit();
/**
* Returns the batch associated {@link Datastore}.
*
* @return The batch associated datastore
*/
Datastore getDatastore();
}