redis には主に次のデータ型があります:
string
##hash
## listset
ソートされたセット
文字列
これは最も単純なタイプで、通常の set と get であり、単純な KV キャッシュを実行します。
set college szuhash
これはマップに似た構造です。これにより、通常、オブジェクト (オブジェクトがネストされていない場合、他のオブジェクト) などの構造化データが許可されます。 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 mylistset
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 mySetsorted set
sorted set は重複を削除するソートセットですが、書き込むとスコアが与えられ、それに応じて自動的にソートされます。スコアに。
rree以上がRedis は通常どのようなデータをキャッシュしますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。