--- acl_categories: - '@read' - '@stream' - '@slow' arguments: - display_text: key key_spec_index: 0 name: key type: key - display_text: end name: end type: string - display_text: start name: start type: string - display_text: count name: count optional: true token: COUNT type: integer arity: -4 categories: - docs - develop - stack - oss - rs - rc - oss - kubernetes - clients command_flags: - readonly complexity: O(N) with N being the number of elements returned. If N is constant (e.g. always asking for the first 10 elements with COUNT), you can consider it O(1). description: Returns the messages from a stream within a range of IDs in reverse order. group: stream hidden: false history: - - 6.2.0 - Added exclusive ranges. key_specs: - RO: true access: true begin_search: spec: index: 1 type: index find_keys: spec: keystep: 1 lastkey: 0 limit: 0 type: range linkTitle: XREVRANGE railroad_diagram: /images/railroad/xrevrange.svg since: 5.0.0 summary: Returns the messages from a stream within a range of IDs in reverse order. syntax_fmt: "XREVRANGE key end start [COUNT\_count]" title: XREVRANGE --- This command is exactly like [`XRANGE`]({{< relref "/commands/xrange" >}}), but with the notable difference of returning the entries in reverse order, and also taking the start-end range in reverse order: in `XREVRANGE` you need to state the *end* ID and later the *start* ID, and the command will produce all the element between (or exactly like) the two IDs, starting from the *end* side. So for instance, to get all the elements from the higher ID to the lower ID one could use: XREVRANGE somestream + - Similarly to get just the last element added into the stream it is enough to send: XREVRANGE somestream + - COUNT 1 ## Examples {{% redis-cli %}} XADD writers * name Virginia surname Woolf XADD writers * name Jane surname Austen XADD writers * name Toni surname Morrison XADD writers * name Agatha surname Christie XADD writers * name Ngozi surname Adichie XLEN writers XREVRANGE writers + - COUNT 1 {{% /redis-cli %}} ## Redis Software and Redis Cloud compatibility | Redis
Software | Redis
Cloud | Notes | |:----------------------|:-----------------|:------| | ✅ Standard
✅ Active-Active | ✅ Standard
✅ Active-Active | | ## Return information {{< multitabs id="xrevrange-return-info" tab1="RESP2" tab2="RESP3" >}} [Array reply](../../develop/reference/protocol-spec#arrays): The command returns the entries with IDs matching the specified range. The returned entries are complete, which means that the ID and all the fields they are composed of are returned. Moreover, the entries are returned with their fields and values in the same order as `XADD` added them. -tab-sep- [Array reply](../../develop/reference/protocol-spec#arrays): The command returns the entries with IDs matching the specified range. The returned entries are complete, which means that the ID and all the fields they are composed of are returned. Moreover, the entries are returned with their fields and values in the same order as `XADD` added them. {{< /multitabs >}}