BITOP
BITOP <AND | OR | XOR | NOT | DIFF | DIFF1 | ANDOR | ONE> destkey key [key ...]
- Available since:
- Redis Open Source 2.6.0
- Time complexity:
- O(N)
- ACL categories:
-
@write
,@bitmap
,@slow
,
Perform a bitwise operation between multiple keys (containing string values) and store the result in the destination key.
The BITOP
command supports eight bitwise operations: AND
, OR
, XOR
,
NOT
, DIFF
, DIFF1
, ANDOR
, and ONE
. The valid forms to call the command are:
-
BITOP AND destkey srckey1 srckey2 srckey3 ... srckeyN
A bit in
destkey
is set only if it is set in all source bitmaps. -
BITOP OR destkey srckey1 srckey2 srckey3 ... srckeyN
A bit in
destkey
is set only if it is set in at least one source bitmap. -
BITOP XOR destkey srckey1 srckey2 srckey3 ... srckeyN
Mostly used with two source bitmaps, a bit in
destkey
is set only if its value differs between the two source bitmaps. -
BITOP NOT destkey srckey
NOT
is a unary operator and only supports a single source bitmap; set the bit to the inverse of its value in the source bitmap. -
BITOP DIFF destkey X [Y1 Y2 ...]
1A bit in
destkey
is set if it is set inX
, but not in any ofY1, Y2, ...
. -
BITOP DIFF1 destkey X [Y1 Y2 ...]
1A bit in
destkey
is set if it is set in one or more ofY1, Y2, ...
, but not inX
. -
BITOP ANDOR destkey X [Y1 Y2 ...]
1A bit in
destkey
is set if it is set inX
and also in one or more ofY1, Y2, ...
. -
BITOP ONE destkey X1 [X2 X3 ...]
1A bit in
destkey
is set if it is set in exactly one ofX1, X2, ...
.
The result of each operation is always stored at destkey
.
Handling of strings with different lengths
When an operation is performed between strings having different lengths, all the strings shorter than the longest string in the set are treated as if they were zero-padded up to the length of the longest string.
The same holds true for non-existent keys, that are considered as a stream of zero bytes up to the length of the longest string.
Examples
- Basic usage example using the
AND
operator:
- Suppose you want to expose people to a book-related ad. The target audience is people who love to read books and are interested in fantasy, adventure, or science fiction. Assume you have the following bitmaps:
LRB
- people who love to read books.B:F
- people interested in fantasy.B:A
- people interested in adventure.B:SF
- people interested in science fiction.
To create a bitmap representing the target audience, use the following command:
BITOP ANDOR TA LRB B:F B:A B:SF
Pattern: real time metrics using bitmaps
BITOP
is a good complement to the pattern documented in the BITCOUNT
command
documentation.
Different bitmaps can be combined in order to obtain a target bitmap where
the population counting operation is performed.
See the article called "Fast easy realtime metrics using Redis bitmaps" for an interesting use cases.
Performance considerations
BITOP
is a potentially slow command as it runs in O(N) time.
Care should be taken when running it against long input strings.
For real-time metrics and statistics involving large inputs a good approach is to use a replica (with replica-read-only option enabled) where the bit-wise operations are performed to avoid blocking the master instance.