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

org.springframework.data.redis.connection.RedisTxCommands Maven / Gradle / Ivy

There is a newer version: 3.2.5
Show newest version
/*
 * Copyright 2011-2018 the original author or 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 org.springframework.data.redis.connection;

import java.util.List;

/**
 * Transaction/Batch specific commands supported by Redis.
 *
 * @author Costin Leau
 * @author Christoph Strobl
 * @author Mark Paluch
 */
public interface RedisTxCommands {

	/**
	 * Mark the start of a transaction block. 
* Commands will be queued and can then be executed by calling {@link #exec()} or rolled back using {@link #discard()} *

* * @see Redis Documentation: MULTI */ void multi(); /** * Executes all queued commands in a transaction started with {@link #multi()}.
* If used along with {@link #watch(byte[]...)} the operation will fail if any of watched keys has been modified. * * @return List of replies for each executed command. * @see Redis Documentation: EXEC */ List exec(); /** * Discard all commands issued after {@link #multi()}. * * @see Redis Documentation: DISCARD */ void discard(); /** * Watch given {@code keys} for modifications during transaction started with {@link #multi()}. * * @param keys must not be {@literal null}. * @see Redis Documentation: WATCH */ void watch(byte[]... keys); /** * Flushes all the previously {@link #watch(byte[]...)} keys. * * @see Redis Documentation: UNWATCH */ void unwatch(); }