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

io.quarkus.redis.datasource.set.SetCommands Maven / Gradle / Ivy

There is a newer version: 3.18.0.CR1
Show newest version
package io.quarkus.redis.datasource.set;

import java.util.List;
import java.util.Set;

import io.quarkus.redis.datasource.RedisCommands;
import io.quarkus.redis.datasource.ScanArgs;
import io.quarkus.redis.datasource.SortArgs;

/**
 * Allows executing commands from the {@code set} group.
 * See the set command list for further information about these commands.
 * 

* A {@code set} is a set of value of type {@code V}. * * @param the type of the key * @param the type of the value stored in the sets */ public interface SetCommands extends RedisCommands { /** * Execute the command SADD. * Summary: Add one or more members to a set * Group: set * Requires Redis 1.0.0 * * @param key the key * @param values the values * @return the number of elements that were added to the set, not including all the elements already present in the set. **/ int sadd(K key, V... values); /** * Execute the command SCARD. * Summary: Get the number of members in a set * Group: set * Requires Redis 1.0.0 * * @param key the key * @return the cardinality (number of elements) of the set, or {@code 0} key does not exist. **/ long scard(K key); /** * Execute the command SDIFF. * Summary: Subtract multiple sets * Group: set * Requires Redis 1.0.0 * * @param keys the keys * @return list with members of the resulting set. **/ Set sdiff(K... keys); /** * Execute the command SDIFFSTORE. * Summary: Subtract multiple sets and store the resulting set in a key * Group: set * Requires Redis 1.0.0 * * @param destination the key * @param keys the keys * @return the number of elements in the resulting set. **/ long sdiffstore(K destination, K... keys); /** * Execute the command SINTER. * Summary: Intersect multiple sets * Group: set * Requires Redis 1.0.0 * * @param keys the keys * @return list with members of the resulting set. **/ Set sinter(K... keys); /** * Execute the command SINTERCARD. * Summary: Intersect multiple sets and return the cardinality of the result * Group: set * Requires Redis 7.0.0 * * @param keys the keys * @return the number of elements in the resulting intersection. **/ long sintercard(K... keys); /** * Execute the command SINTERCARD. * Summary: Intersect multiple sets and return the cardinality of the result * Group: set * Requires Redis 7.0.0 * * @param limit When provided with the optional LIMIT argument (which defaults to 0 and means unlimited), * if the intersection cardinality reaches limit partway through the computation, the algorithm * will exit and yield limit as the cardinality. * @param keys the keys * @return the number of elements in the resulting intersection. **/ long sintercard(int limit, K... keys); /** * Execute the command SINTERSTORE. * Summary: Intersect multiple sets and store the resulting set in a key * Group: set * Requires Redis 1.0.0 * * @param destination the key * @param keys the keys * @return the number of elements in the resulting set. **/ long sinterstore(K destination, K... keys); /** * Execute the command SISMEMBER. * Summary: Determine if a given value is a member of a set * Group: set * Requires Redis 1.0.0 * * @param key the key * @param member the member to check * @return {@code true} the element is a member of the set. {@code false} the element is not a member of the * set, or if key does not exist. **/ boolean sismember(K key, V member); /** * Execute the command SMEMBERS. * Summary: Get all the members in a set * Group: set * Requires Redis 1.0.0 * * @param key the key * @return all elements of the set. **/ Set smembers(K key); /** * Execute the command SMISMEMBER. * Summary: Returns the membership associated with the given elements for a set * Group: set * Requires Redis 6.2.0 * * @param key the key * @param members the members to check * @return list representing the membership of the given elements, in the same order as they are requested. **/ List smismember(K key, V... members); /** * Execute the command SMOVE. * Summary: Move a member from one set to another * Group: set * Requires Redis 1.0.0 * * @param source the key * @param destination the key * @param member the member to move * @return {@code true} the element is moved. {@code false} the element is not a member of source and no operation was * performed. **/ boolean smove(K source, K destination, V member); /** * Execute the command SPOP. * Summary: Remove and return one or multiple random members from a set * Group: set * Requires Redis 1.0.0 * * @param key the key * @return the removed member, or {@code null} when key does not exist. **/ V spop(K key); /** * Execute the command SPOP. * Summary: Remove and return one or multiple random members from a set * Group: set * Requires Redis 1.0.0 * * @param key the key * @return the removed members, or an empty array when key does not exist. **/ Set spop(K key, int count); /** * Execute the command SRANDMEMBER. * Summary: Get one or multiple random members from a set * Group: set * Requires Redis 1.0.0 * * @param key the key * @return the randomly selected element, or {@code null} when key does not exist. **/ V srandmember(K key); /** * Execute the command SRANDMEMBER. * Summary: Get one or multiple random members from a set * Group: set * Requires Redis 1.0.0 * * @param key the key * @param count the number of elements to pick * @return an array of elements, or an empty array when key does not exist. **/ List srandmember(K key, int count); /** * Execute the command SREM. * Summary: Remove one or more members from a set * Group: set * Requires Redis 1.0.0 * * @param key the key * @return the number of members that were removed from the set, not including non-existing members. **/ int srem(K key, V... members); /** * Execute the command SUNION. * Summary: Add multiple sets * Group: set * Requires Redis 1.0.0 * * @param keys the keys * @return list with members of the resulting set. **/ Set sunion(K... keys); /** * Execute the command SUNIONSTORE. * Summary: Add multiple sets and store the resulting set in a key * Group: set * Requires Redis 1.0.0 * * @param destination the destination key * @param keys the keys * @return the number of elements in the resulting set. **/ long sunionstore(K destination, K... keys); /** * Execute the command SSCAN. * Summary: Incrementally iterate Set elements * Group: set * Requires Redis 2.8.0 * * @param key the key * @return the cursor **/ SScanCursor sscan(K key); /** * Execute the command SSCAN. * Summary: Incrementally iterate Set elements * Group: set * Requires Redis 2.8.0 * * @param key the key * @param scanArgs the extra parameters * @return the cursor **/ SScanCursor sscan(K key, ScanArgs scanArgs); /** * Execute the command SORT. * Summary: Sort the elements in a list, set or sorted set * Group: generic * Requires Redis 1.0.0 * * @return the list of sorted elements. **/ List sort(K key); /** * Execute the command SORT. * Summary: Sort the elements in a list, set or sorted set * Group: generic * Requires Redis 1.0.0 * * @param key the key * @param sortArguments the {@code SORT} command extra-arguments * @return the list of sorted elements. **/ List sort(K key, SortArgs sortArguments); /** * Execute the command SORT with the {@code STORE} option. * Summary: Sort the elements in a list, set or sorted set * Group: generic * Requires Redis 1.0.0 * * @param sortArguments the SORT command extra-arguments * @return the number of sorted elements in the destination list. **/ long sortAndStore(K key, K destination, SortArgs sortArguments); /** * Execute the command SORT with the {@code STORE} option. * Summary: Sort the elements in a list, set or sorted set * Group: generic * Requires Redis 1.0.0 * * @return the number of sorted elements in the destination list. **/ long sortAndStore(K key, K destination); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy