Redis Sorted Set: Copy (Detailed Guide w/ Code Examples)

Use Case(s)

Copying a Redis sorted set is useful when you need to replicate the data for backup purposes, perform operations without affecting the original set, or create subsets of data based on specific criteria.

Code Examples


Using zrange and zadd commands with Redis-py:

import redis r = redis.Redis() source_set = 'source_sorted_set' destination_set = 'destination_sorted_set' # Fetch all elements from the source sorted set elements = r.zrange(source_set, 0, -1, withscores=True) # Add elements to the destination sorted set for element, score in elements: r.zadd(destination_set, {element: score})


Using ZRANGE and ZADD commands with node-redis:

const redis = require('redis'); const client = redis.createClient(); const sourceSet = 'source_sorted_set'; const destSet = 'destination_sorted_set'; client.zrange(sourceSet, 0, -1, 'WITHSCORES', (err, elements) => { if (err) throw err; const zaddArgs = []; for (let i = 0; i < elements.length; i += 2) { zaddArgs.push(elements[i+1]); zaddArgs.push(elements[i]); } client.zadd(destSet, zaddArgs, (err, res) => { if (err) throw err; console.log('Sorted set copied successfully'); client.quit(); }); });


Using ZRANGE and ZADD commands with go-redis:

package main import ( "" "context" "fmt" ) func main() { ctx := context.Background() rdb := redis.NewClient(&redis.Options{ Addr: "localhost:6379", }) sourceSet := "source_sorted_set" destSet := "destination_sorted_set" elements, err := rdb.ZRangeWithScores(ctx, sourceSet, 0, -1).Result() if err != nil { panic(err) } for _, z := range elements { rdb.ZAdd(ctx, destSet, &redis.Z{ Score: z.Score, Member: z.Member, }) } fmt.Println("Sorted set copied successfully") }

Best Practices

  • Ensure the destination sorted set doesn't already contain unwanted data before copying.
  • Handle errors during the copy process to avoid incomplete data transfer.
  • Consider using pipelining or batching techniques for large datasets to improve performance.

Common Mistakes

  • Overwriting an existing sorted set unintentionally.
  • Not handling connection errors which may result in partial data copies.
  • Forgetting to fetch scores along with members, leading to loss of ordering.

Was this content helpful?

Start building today

Dragonfly is fully compatible with the Redis ecosystem and requires no code changes to implement.