1. Data structure

A deep understanding of these five data structures, how they work, the methods they provide, and how to use these data structures for modeling is key to learning and understanding Redis. The first step is to understand what these data structures mean.

Five data structures

  • (1) Strings
  • (2) Hashes
  • (3) Lists
  • (4) Sets
  • 5) Sorted Sets

1.1 Strings (String Structure)

In the classic key-value pair structure, value can be understood simply as a string, but it can also be an integer.

Key words: set, get

1.1.1 Value is a serializable string

In most cases, Redis treats a value as an array of bytes. Can store characters, formatted serialized strings (JSON, XML), etc. Example:

// Set users:leto '{"name": leto, "planet": dune, "likes": ["spice"]}' // read get users:leto // get the length strlen USERS :leto // Get the characters in the range getrange Users :leto 31 48 // append to the end append users:leto " OVER 9000!!"Copy the code

1.1.2 Value can also be a number

Generally do some complex counting function of the cache. Adding or subtracting values is shown below:

Incrby ratings:video:12333 5 incr stats: Page :about incrby ratings:video:12333 5Copy the code

1.2 Hashes (Hash structure)

The hash structure adds another intermediate layer: fields. It’s like describing a person named John, he also has the name, age, and other fields.

Key words: hset, hGET

Example:

  hset users:goku powerlevel 9000
  hget users:goku powerlevel
Copy the code

Hset users:goku powerlevel 9000 hset users:goku powerlevel 9000

Multiple fields can be processed in batches. Example:

Hmget Users :goku race PowerLevel // Get all fields and values hgetall Users :goku // List all fields hkeys Users :goku // Delete specified fields: hdel Users :goku ageCopy the code

It’s much less granular, and it’s very convenient that you can pull, update, and delete specified fields without having to manipulate the entire value.

And indeed, from a performance point of view, the operation of finer particles is necessary.

1.3 Lists

Its value is stored as an array.

Key words: LPUSH, Rpush, Ltrim, LLEN

You can insert a value into an array, get the first or last value, and manipulate the value at the specified index position.

Example:

Rpush newUsers goku rpush newUsers goku rpush newUsers goku rpush newUsers goku rpush newUsers goku rpush newUsers goku rpush newUsers 0 49 Ltrim newUsers 0 49Copy the code

You can use a list structure to store logs or to track a user’s path to a web site. It can be used as a queue.

1.4 Sets

Collection structures are used to store unique values. The set is unordered. It provides a set of set-based operations, such as union operations.

Key words: sadd, sismember

Example:

// Add sadd Friends :leto ghanima Paul Chani Jessica // add sismember Friends :leto Jessica // Add sinter friends:leto // You can simply store this result in a new key: Sinterstore Friends :leto_duncan Friends :leto Friends: DuncanCopy the code

Collections are great when you need to mark or track values that have duplicate attributes. Or when we want to use a merge operation of sets.

3. Sorted Sets

An ordered set structure is just like a set structure, but with weights (score).

Keywords: zadd, zcount, zRevrank

Weights provide sorting and ranking capabilities. If we want to see the ranking of our friends, we can do this:

// value has a number of values, Each set a number to indicate the weight of Zadd friends: Duncan 70 Ghanima 95 Paul 95 Chani 75 Jessica 1 Vladimir // The weight is zcount of 90 and above Zrevrank Friends: Duncan chaniCopy the code

Instead of ZRank, you can use ZRevRank, which is sorted from lowest to highest by default. The most common use case for ordered collections is the leaderboard system.

1.6 summary

Each data type has its own application scenario, depending on business needs.

END