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

com.google.cloud.datastore.Batch Maven / Gradle / Ivy

The newest version!
/*
 * 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(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy