Module: Redis::Commands::Transactions

Included in:
Redis::Commands
Defined in:
lib/redis/commands/transactions.rb

Instance Method Summary collapse

Instance Method Details

#discardString

Discard all commands issued after MULTI.

Only call this method when ‘#multi` was called without a block.

Returns:

  • (String)

    ‘“OK”`

See Also:



87
88
89
# File 'lib/redis/commands/transactions.rb', line 87

def discard
  send_command([:discard])
end

#execnil, Array<...>

Execute all commands issued after MULTI.

Only call this method when ‘#multi` was called without a block.

Returns:

  • (nil, Array<...>)
    • when commands were not executed, ‘nil`

    • when commands were executed, an array with their replies

See Also:



75
76
77
# File 'lib/redis/commands/transactions.rb', line 75

def exec
  send_command([:exec])
end

#unwatchString

Forget about all watched keys.

Returns:

  • (String)

    ‘OK`

See Also:



61
62
63
# File 'lib/redis/commands/transactions.rb', line 61

def unwatch
  send_command([:unwatch])
end

#watch(*keys) ⇒ Object, String

Watch the given keys to determine execution of the MULTI/EXEC block.

Using a block is optional, but is necessary for thread-safety.

An ‘#unwatch` is automatically issued if an exception is raised within the block that is a subclass of StandardError and is not a ConnectionError.

Examples:

With a block

redis.watch("key") do
  if redis.get("key") == "some value"
    redis.multi do |multi|
      multi.set("key", "other value")
      multi.incr("counter")
    end
  else
    redis.unwatch
  end
end
  # => ["OK", 6]

Without a block

redis.watch("key")
  # => "OK"

Parameters:

  • keys (String, Array<String>)

    one or more keys to watch

Returns:

  • (Object)

    if using a block, returns the return value of the block

  • (String)

    if not using a block, returns ‘OK`

See Also:



36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
# File 'lib/redis/commands/transactions.rb', line 36

def watch(*keys)
  synchronize do |client|
    res = client.call([:watch, *keys])

    if block_given?
      begin
        yield(self)
      rescue ConnectionError
        raise
      rescue StandardError
        unwatch
        raise
      end
    else
      res
    end
  end
end