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

com.couchbase.client.java.batch.BatchHelper Maven / Gradle / Ivy

/*
 * Copyright (c) 2020 Couchbase, Inc.
 *
 * 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.couchbase.client.java.batch;

import com.couchbase.client.core.annotation.Stability;
import com.couchbase.client.java.Collection;
import com.couchbase.client.java.kv.GetResult;

import java.util.List;
import java.util.Map;

/**
 * This helper class provides methods that make performing batch operations easy and comfortable.
 */
@Stability.Uncommitted
public class BatchHelper {

  private BatchHelper() {}

  /**
   * First checks if the given IDs exist and if so fetches their contents.
   * 

* Please take into consideration when using this API that it only makes sense to use it if of the many ids provided * only a small subset comes back. (So let's say you give it 1000 IDs but you only expect 50 to be there or so). * Otherwise if all are most of them are there, just use a bulk get with the reactive API directly - you won't see * much benefit in this case. * * @param collection the collection to perform the fetch on. * @param ids the document IDs to fetch. * @return a Map of the document IDs as the key and the result (if found). */ @Stability.Uncommitted public static Map getIfExists(final Collection collection, final java.util.Collection ids) { return ReactiveBatchHelper.getIfExists(collection, ids).block(); } /** * Returns a list of ids for the documents that exist. *

* Note that you usually only want to use this API if you really need to bulk check exists on many documents * at once, for all other use cases we recommend trying the regular, supported APIs first * (i.e. using {@link com.couchbase.client.java.ReactiveCollection#exists(String)}). * * @param collection the collection to perform the exists checks on. * @param ids the document IDs to check. * @return a list of all the ids that are found. */ @Stability.Uncommitted public static List exists(final Collection collection, final java.util.Collection ids) { return ReactiveBatchHelper.exists(collection, ids).collectList().block(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy