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

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

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

import io.quarkus.redis.datasource.TransactionalRedisCommands;

public interface TransactionalSetCommands extends TransactionalRedisCommands {

    /**
     * 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
     */
    void 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
     */
    void scard(K key);

    /**
     * Execute the command SDIFF.
     * Summary: Subtract multiple sets
     * Group: set
     * Requires Redis 1.0.0
     *
     * @param keys the keys
     */
    void 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
     */
    void sdiffstore(K destination, K... keys);

    /**
     * Execute the command SINTER.
     * Summary: Intersect multiple sets
     * Group: set
     * Requires Redis 1.0.0
     *
     * @param keys the keys
     */
    void 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
     */
    void 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
     */
    void 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
     */
    void 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
     */
    void 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
     */
    void 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
     */
    void 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
     */
    void 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
     */
    void 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
     */
    void 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
     */
    void 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
     */
    void 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
     */
    void srem(K key, V... members);

    /**
     * Execute the command SUNION.
     * Summary: Add multiple sets
     * Group: set
     * Requires Redis 1.0.0
     *
     * @param keys the keys
     */
    void 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
     */
    void sunionstore(K destination, K... keys);

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy