ホームページ >データベース >Redis >Redis は通常どのようなデータをキャッシュしますか?

Redis は通常どのようなデータをキャッシュしますか?

anonymity
anonymityオリジナル
2019-06-05 16:27:036934ブラウズ

redis には主に次のデータ型があります:

string

##hash

## list

set

ソートされたセット

Redis は通常どのようなデータをキャッシュしますか?

文字列

これは最も単純なタイプで、通常の set と get であり、単純な KV キャッシュを実行します。

set college szu

hash

これはマップに似た構造です。これにより、通常、オブジェクト (オブジェクトがネストされていない場合、他のオブジェクト) などの構造化データが許可されます。 Redis にキャッシュされているため、キャッシュの読み取りまたは書き込みのたびに、ハッシュ内の特定のフィールドを操作できます。

hset person name bingo
hset person age 20
hset person id 1
hget person name
person = {
    "name": "bingo",
    "age": 20,
    "id": 1
}

list

list は順序付きリストであり、さまざまな方法で使用できます。

たとえば、list を使用して、ファン リスト、記事コメント リストなどのリスト タイプのデータ構造を保存できます。

たとえば、lrange コマンドを使用して、特定の閉じた範囲内の要素を読み取ることができ、リストに基づいてページング クエリを実装できます。これは素晴らしい機能です。redis に基づいて、シンプルな高機能を実装できます。パフォーマンス ページング、マイクロ ボーのようなことを行うことができます。ドロップダウンと連続ページネーションのようなもので、パフォーマンスが高く、ページごとに移動できます。

# 開始位置 0、終了位置 -1 終了位置が -1 の場合、リストの最後の位置、つまりすべてを表示することを意味します。

lrange mylist 0 -1

たとえば、単純なメッセージ キューを作成し、リストの先頭から入力し、リストの末尾から取り出すことができます。

lpush mylist 1
lpush mylist 2
lpush mylist 3 4 5
# 1
rpop mylist

set

set は、重複を自動的に削除する順序なしセットです。

重複排除する必要があるデータをセットに基づいてシステムに直接スローすると、自動的に重複排除されます。一部のデータを迅速にグローバルに重複排除する必要がある場合は、もちろん HashSet を使用することもできます。 jvm メモリ 重複排除を実行しますが、システムの 1 つが複数のマシンに展開されている場合はどうなるでしょうか?グローバル セットの重複排除は、redis に基づいて実行する必要があります。

集合に基づいて交差、和集合、差分演算を実行できます。たとえば、交差する場合、2 人のファン リストを結合して、共通の友達が誰であるかを確認できます。右。

2 つの大きな V のファンを 2 つのセットに入れ、2 つのセット間に交差を作成します。

#-------操作一个set-------
# 添加元素
sadd mySet 1
# 查看全部元素
smembers mySet
# 判断是否包含某个值
sismember mySet 3
# 删除某个/些元素
srem mySet 1
srem mySet 2 4
# 查看元素个数
scard mySet
# 随机删除一个元素
spop mySet
#-------操作多个set-------
# 将一个set的元素移动到另外一个set
smove yourSet mySet 2
# 求两set的交集
sinter yourSet mySet
# 求两set的并集
sunion yourSet mySet
# 求在yourSet中而不在mySet中的元素
sdiff yourSet mySet

sorted set

sorted set は重複を削除するソートセットですが、書き込むとスコアが与えられ、それに応じて自動的にソートされます。スコアに。

rree

以上がRedis は通常どのようなデータをキャッシュしますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。