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

com.apple.foundationdb.ReadTransaction Maven / Gradle / Ivy

/*
 * ReadTransaction.java
 *
 * This source file is part of the FoundationDB open source project
 *
 * Copyright 2013-2018 Apple Inc. and the FoundationDB project authors
 *
 * 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.apple.foundationdb;

import java.util.concurrent.CompletableFuture;

import com.apple.foundationdb.async.AsyncIterable;
import com.apple.foundationdb.async.AsyncIterator;
import com.apple.foundationdb.tuple.Tuple;

/**
 * A read-only subset of a FoundationDB {@link Transaction}. This is the interface that
 *  {@code Transaction}'s {@link Transaction#snapshot snapshot} presents.
*
* Note: Client must call {@link Transaction#commit()} and wait on the result on all transactions, * even ones that only read. This is done automatically when using the retry loops from * {@link Database#run(java.util.function.Function)}. This is explained more in the intro to {@link Transaction}. * * @see Transaction */ public interface ReadTransaction extends ReadTransactionContext { /** * When passed to a {@code getRange()} call that takes a {@code limit} parameter, * indicates that the query should return unlimited rows. */ int ROW_LIMIT_UNLIMITED = 0; /** * Gets whether this transaction is a snapshot view of the database. In other words, this returns * whether read conflict ranges are omitted for any reads done through this {@code ReadTransaction}. *
* For more information about how to use snapshot reads correctly, see * Using snapshot reads. * * @return whether this is a snapshot view of the database with relaxed isolation properties * @see #snapshot() */ boolean isSnapshot(); /** * Return a special-purpose, read-only view of the database. Reads done through this interface are known as "snapshot reads". * Snapshot reads selectively relax FoundationDB's isolation property, reducing * Transaction conflicts * but making reasoning about concurrency harder.
*
* For more information about how to use snapshot reads correctly, see * Using snapshot reads. * * @return a read-only view of this {@code ReadTransaction} with relaxed isolation properties */ ReadTransaction snapshot(); /** * Gets the version at which the reads for this {@code Transaction} will access the database. * @return the version for database reads */ CompletableFuture getReadVersion(); /** * Directly sets the version of the database at which to execute reads. The * normal operation of a transaction is to determine an appropriately recent * version; this call overrides that behavior. If the version is set too * far in the past, {@code transaction_too_old} errors will be thrown from read operations. * Infrequently used. * * @param version the version at which to read from the database */ void setReadVersion(long version); /** * Adds the read conflict range that this {@code ReadTransaction} would have added as if it had read * the given key range. If this is a {@linkplain #snapshot() snapshot} view of the database, this will * not add the conflict range. This mirrors how reading a range through a snapshot view * of the database does not add a conflict range for the read keys. * * @param keyBegin the first key in the range (inclusive) * @param keyEnd the last key in the range (exclusive) * @return {@code true} if the read conflict range was added and {@code false} otherwise * @see Transaction#addReadConflictRange(byte[], byte[]) */ boolean addReadConflictRangeIfNotSnapshot(byte[] keyBegin, byte[] keyEnd); /** * Adds the read conflict range that this {@code ReadTransaction} would have added as if it had read * the given key. If this is a {@linkplain #snapshot() snapshot} view of the database, this will * not add the conflict range. This mirrors how reading a key through a snapshot view * of the database does not add a conflict range for the read key. * * @param key the key to add to the read conflict range set (it this is not a snapshot view of the database) * @return {@code true} if the read conflict key was added and {@code false} otherwise * @see Transaction#addReadConflictKey(byte[]) */ boolean addReadConflictKeyIfNotSnapshot(byte[] key); /** * Gets a value from the database. The call will return {@code null} if the key is not * present in the database. * * @param key the key whose value to fetch from the database * * @return a {@code CompletableFuture} which will be set to the value corresponding to * the key or to null if the key does not exist. */ CompletableFuture get(byte[] key); /** * Returns the key referenced by the specified {@code KeySelector}. * By default, the key is cached for the duration of the transaction, providing * a potential performance benefit. However, the value of the key is also retrieved, * using network bandwidth. Invoking {@code setReadYourWritesDisable} will avoid * both the caching and the increased network bandwidth. * * @see KeySelector * * @param selector the relative key location to resolve * * @return a {@code CompletableFuture} which will be set to an absolute database key */ CompletableFuture getKey(KeySelector selector); /** * Gets an ordered range of keys and values from the database. The begin * and end keys are specified by {@code KeySelector}s, with the begin * {@code KeySelector} inclusive and the end {@code KeySelector} exclusive. * * @see KeySelector * @see AsyncIterator * * @param begin the beginning of the range (inclusive) * @param end the end of the range (exclusive) * * @return a handle to access the results of the asynchronous call */ AsyncIterable getRange(KeySelector begin, KeySelector end); /** * Gets an ordered range of keys and values from the database. The begin * and end keys are specified by {@code KeySelector}s, with the begin * {@code KeySelector} inclusive and the end {@code KeySelector} exclusive. * * @see KeySelector * @see AsyncIterator * * @param begin the beginning of the range (inclusive) * @param end the end of the range (exclusive) * @param limit the maximum number of results to return. Limits results to the * first keys in the range. Pass {@link #ROW_LIMIT_UNLIMITED} if this query * should not limit the number of results. * * @return a handle to access the results of the asynchronous call */ AsyncIterable getRange(KeySelector begin, KeySelector end, int limit); /** * Gets an ordered range of keys and values from the database. The begin * and end keys are specified by {@code KeySelector}s, with the begin * {@code KeySelector} inclusive and the end {@code KeySelector} exclusive. * * @see KeySelector * @see AsyncIterator * * @param begin the beginning of the range (inclusive) * @param end the end of the range (exclusive) * @param limit the maximum number of results to return. Limits results to the * first keys in the range. Pass {@link #ROW_LIMIT_UNLIMITED} if this query * should not limit the number of results. If {@code reverse} is {@code true} rows * will be limited starting at the end of the range. * @param reverse return results starting at the end of the range in reverse order. * Reading ranges in reverse is supported natively by the database and should * have minimal extra cost. * * @return a handle to access the results of the asynchronous call */ AsyncIterable getRange(KeySelector begin, KeySelector end, int limit, boolean reverse); /** * Gets an ordered range of keys and values from the database. The begin * and end keys are specified by {@code KeySelector}s, with the begin * {@code KeySelector} inclusive and the end {@code KeySelector} exclusive. * * @see KeySelector * @see AsyncIterator * * @param begin the beginning of the range (inclusive) * @param end the end of the range (exclusive) * @param limit the maximum number of results to return. Limits results to the * first keys in the range. Pass {@link #ROW_LIMIT_UNLIMITED} if this query * should not limit the number of results. If {@code reverse} is {@code true} rows * will be limited starting at the end of the range. * @param reverse return results starting at the end of the range in reverse order. * Reading ranges in reverse is supported natively by the database and should * have minimal extra cost. * @param mode provide a hint about how the results are to be used. This * can provide speed improvements or efficiency gains based on the caller's * knowledge of the upcoming access pattern. * *

* When converting the result of this query to a list using {@link AsyncIterable#asList()} with the {@code ITERATOR} streaming * mode, the query is automatically modified to fetch results in larger batches. This is done because it is * known in advance that the {@link AsyncIterable#asList()} function will fetch all results in the range. If a limit is specified, * the {@code EXACT} streaming mode will be used, and otherwise it will use {@code WANT_ALL}. * * To achieve comparable performance when iterating over an entire range without using {@link AsyncIterable#asList()}, the same * streaming mode would need to be used. *

* @return a handle to access the results of the asynchronous call */ AsyncIterable getRange(KeySelector begin, KeySelector end, int limit, boolean reverse, StreamingMode mode); /** * Gets an ordered range of keys and values from the database. The begin * and end keys are specified by {@code byte[]} arrays, with the begin * key inclusive and the end key exclusive. * * @see KeySelector * @see AsyncIterator * * @param begin the beginning of the range (inclusive) * @param end the end of the range (exclusive) * * @return a handle to access the results of the asynchronous call */ AsyncIterable getRange(byte[] begin, byte[] end); /** * Gets an ordered range of keys and values from the database. The begin * and end keys are specified by {@code byte[]} arrays, with the begin * key inclusive and the end key exclusive. * * @see KeySelector * @see AsyncIterator * * @param begin the beginning of the range (inclusive) * @param end the end of the range (exclusive) * @param limit the maximum number of results to return. Limits results to the * first keys in the range. Pass {@link #ROW_LIMIT_UNLIMITED} if this query * should not limit the number of results. * * @return a handle to access the results of the asynchronous call */ AsyncIterable getRange(byte[] begin, byte[] end, int limit); /** * Gets an ordered range of keys and values from the database. The begin * and end keys are specified by {@code byte[]} arrays, with the begin * key inclusive and the end key exclusive. * * @see KeySelector * @see AsyncIterator * * @param begin the beginning of the range (inclusive) * @param end the end of the range (exclusive) * @param limit the maximum number of results to return. Limits results to the * first keys in the range. Pass {@link #ROW_LIMIT_UNLIMITED} if this query * should not limit the number of results. If {@code reverse} is {@code true} rows * will be limited starting at the end of the range. * @param reverse return results starting at the end of the range in reverse order. * Reading ranges in reverse is supported natively by the database and should * have minimal extra cost. * * @return a handle to access the results of the asynchronous call */ AsyncIterable getRange(byte[] begin, byte[] end, int limit, boolean reverse); /** * Gets an ordered range of keys and values from the database. The begin * and end keys are specified by {@code byte[]} arrays, with the begin * key inclusive and the end key exclusive. * * @see KeySelector * @see AsyncIterator * * @param begin the beginning of the range (inclusive) * @param end the end of the range (exclusive) * @param limit the maximum number of results to return. Limits results to the * first keys in the range. Pass {@link #ROW_LIMIT_UNLIMITED} if this query * should not limit the number of results. If {@code reverse} is {@code true} rows * will be limited starting at the end of the range. * @param reverse return results starting at the end of the range in reverse order. * Reading ranges in reverse is supported natively by the database and should * have minimal extra cost. * @param mode provide a hint about how the results are to be used. This * can provide speed improvements or efficiency gains based on the caller's * knowledge of the upcoming access pattern. * *

* When converting the result of this query to a list using {@link AsyncIterable#asList()} with the {@code ITERATOR} streaming * mode, the query is automatically modified to fetch results in larger batches. This is done because it is * known in advance that the {@link AsyncIterable#asList()} function will fetch all results in the range. If a limit is specified, * the {@code EXACT} streaming mode will be used, and otherwise it will use {@code WANT_ALL}. * * To achieve comparable performance when iterating over an entire range without using {@link AsyncIterable#asList()}, the same * streaming mode would need to be used. *

* @return a handle to access the results of the asynchronous call */ AsyncIterable getRange(byte[] begin, byte[] end, int limit, boolean reverse, StreamingMode mode); /** * Gets an ordered range of keys and values from the database. The begin * and end keys are specified by {@code byte[]} arrays, with the begin * key inclusive and the end key exclusive. {@link Range}s are returned * from calls to {@link Tuple#range()} and {@link Range#startsWith(byte[])}.
*
* Note: users of older version of the API should replace old calls to * {@code getRangeStartsWith( k )} with {@code getRange(Range.startsWith( k ))} * * @see KeySelector * @see AsyncIterator * * @param range the range of keys to return * * @return a handle to access the results of the asynchronous call */ AsyncIterable getRange(Range range); /** * Gets an ordered range of keys and values from the database. The begin * and end keys are specified by {@code byte[]} arrays, with the begin * key inclusive and the end key exclusive. {@link Range}s are returned * from calls to {@link Tuple#range()} and {@link Range#startsWith(byte[])}.
*
* Note: users of older version of the API should replace old calls to * {@code getRangeStartsWith( k )} with {@code getRange(Range.startsWith( k ))} * * @see KeySelector * @see AsyncIterator * * @param range the range of keys to return * @param limit the maximum number of results to return. Limits results to the * first keys in the range. Pass {@link #ROW_LIMIT_UNLIMITED} if this query * should not limit the number of results. * * @return a handle to access the results of the asynchronous call */ AsyncIterable getRange(Range range, int limit); /** * Gets an ordered range of keys and values from the database. The begin * and end keys are specified by {@code byte[]} arrays, with the begin * key inclusive and the end key exclusive. {@link Range}s are returned * from calls to {@link Tuple#range()} and {@link Range#startsWith(byte[])}.
*
* Note: users of older version of the API should replace old calls to * {@code getRangeStartsWith( k )} with {@code getRange(Range.startsWith( k ))} * * @see KeySelector * @see AsyncIterator * * @param range the range of keys to return * @param limit the maximum number of results to return. Limits results to the * first keys in the range. Pass {@link #ROW_LIMIT_UNLIMITED} if this query * should not limit the number of results. If {@code reverse} is {@code true} rows * will be limited starting at the end of the range. * @param reverse return results starting at the end of the range in reverse order. * Reading ranges in reverse is supported natively by the database and should * have minimal extra cost. * * @return a handle to access the results of the asynchronous call */ AsyncIterable getRange(Range range, int limit, boolean reverse); /** * Gets an ordered range of keys and values from the database. The begin * and end keys are specified by {@code byte[]} arrays, with the begin * key inclusive and the end key exclusive. {@link Range}s are returned * from calls to {@link Tuple#range()} and {@link Range#startsWith(byte[])}.
*
* Note: users of older version of the API should replace old calls to * {@code getRangeStartsWith( k )} with {@code getRange(Range.startsWith( k ))} * * @see KeySelector * @see AsyncIterator * * @param range the range of keys to return * @param limit the maximum number of results to return. Limits results to the * first keys in the range. Pass {@link #ROW_LIMIT_UNLIMITED} if this query * should not limit the number of results. If {@code reverse} is {@code true} rows * will be limited starting at the end of the range. * @param reverse return results starting at the end of the range in reverse order. * Reading ranges in reverse is supported natively by the database and should * have minimal extra cost. * @param mode provide a hint about how the results are to be used. This * can provide speed improvements or efficiency gains based on the caller's * knowledge of the upcoming access pattern. * *

* When converting the result of this query to a list using {@link AsyncIterable#asList()} with the {@code ITERATOR} streaming * mode, the query is automatically modified to fetch results in larger batches. This is done because it is * known in advance that the {@link AsyncIterable#asList()} function will fetch all results in the range. If a limit is specified, * the {@code EXACT} streaming mode will be used, and otherwise it will use {@code WANT_ALL}. * * To achieve comparable performance when iterating over an entire range without using {@link AsyncIterable#asList()}, the same * streaming mode would need to be used. *

* @return a handle to access the results of the asynchronous call */ AsyncIterable getRange(Range range, int limit, boolean reverse, StreamingMode mode); /** * WARNING: This feature is considered experimental at this time. It is only allowed when using snapshot isolation * AND disabling read-your-writes. * * @see KeySelector * @see AsyncIterator * * @param begin the beginning of the range (inclusive) * @param end the end of the range (exclusive) * @param mapper defines how to map a key-value pair (one of the key-value pairs got * from the first range query) to a GetRange (or GetValue) request. * more details: https://github.com/apple/foundationdb/wiki/Everything-about-GetMappedRange * @param limit the maximum number of results to return. Limits results to the * first keys in the range. Pass {@link #ROW_LIMIT_UNLIMITED} if this query * should not limit the number of results. If {@code reverse} is {@code true} rows * will be limited starting at the end of the range. * @param reverse return results starting at the end of the range in reverse order. * Reading ranges in reverse is supported natively by the database and should * have minimal extra cost. * @param mode provide a hint about how the results are to be used. This * can provide speed improvements or efficiency gains based on the caller's * knowledge of the upcoming access pattern. * *

* When converting the result of this query to a list using {@link AsyncIterable#asList()} with the {@code * ITERATOR} streaming mode, the query is automatically modified to fetch results in larger batches. This is done * because it is known in advance that the {@link AsyncIterable#asList()} function will fetch all results in the * range. If a limit is specified, the {@code EXACT} streaming mode will be used, and otherwise it will use {@code * WANT_ALL}. * * To achieve comparable performance when iterating over an entire range without using {@link * AsyncIterable#asList()}, the same streaming mode would need to be used. *

* @return a handle to access the results of the asynchronous call */ AsyncIterable getMappedRange(KeySelector begin, KeySelector end, byte[] mapper, int limit, boolean reverse, StreamingMode mode); /** * Gets an estimate for the number of bytes stored in the given range. * Note: the estimated size is calculated based on the sampling done by FDB server. The sampling * algorithm works roughly in this way: the larger the key-value pair is, the more likely it would * be sampled and the more accurate its sampled size would be. And due to * that reason it is recommended to use this API to query against large ranges for accuracy considerations. * For a rough reference, if the returned size is larger than 3MB, one can consider the size to be * accurate. * * @param begin the beginning of the range (inclusive) * @param end the end of the range (exclusive) * * @return a handle to access the results of the asynchronous call */ CompletableFuture getEstimatedRangeSizeBytes(byte[] begin, byte[] end); /** * Gets an estimate for the number of bytes stored in the given range. * Note: the estimated size is calculated based on the sampling done by FDB server. The sampling * algorithm works roughly in this way: the larger the key-value pair is, the more likely it would * be sampled and the more accurate its sampled size would be. And due to * that reason it is recommended to use this API to query against large ranges for accuracy considerations. * For a rough reference, if the returned size is larger than 3MB, one can consider the size to be * accurate. * @param range the range of the keys * * @return a handle to access the results of the asynchronous call */ CompletableFuture getEstimatedRangeSizeBytes(Range range); /** * Gets a list of keys that can split the given range into (roughly) equally sized chunks based on chunkSize. * Note: the returned split points contain the start key and end key of the given range. * * @param begin the beginning of the range (inclusive) * @param end the end of the range (exclusive) * @param chunkSize -- undocumented * * @return a handle to access the results of the asynchronous call */ CompletableFuture getRangeSplitPoints(byte[] begin, byte[] end, long chunkSize); /** * Gets a list of keys that can split the given range into (roughly) equally sized chunks based on chunkSize * Note: the returned split points contain the start key and end key of the given range. * * @param range the range of the keys * @param chunkSize -- undocumented * * @return a handle to access the results of the asynchronous call */ CompletableFuture getRangeSplitPoints(Range range, long chunkSize); /** * Gets the blob granule ranges for a given region. * Returned in batches, requires calling again moving the begin key up. * * @param begin beginning of the range (inclusive) * @param end end of the range (exclusive) * @param rowLimit the limit on the number of returned rows * @return list of blob granules in the given range. May not be all. */ CompletableFuture getBlobGranuleRanges(byte[] begin, byte[] end, int rowLimit); /** * Returns a set of options that can be set on a {@code Transaction} * * @return a set of transaction-specific options affecting this {@code Transaction} */ TransactionOptions options(); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy