redis 常用命令

編號????????????????????????????命令????????????????????????????????????????描述

1? ? ? ? ? ? ? ? ? ? ? ? ? ? DEL key? ? ? ? ? ? ? ? ? ? ? ????????????????此命令刪除一個指定鍵(如果存在)。

2? ? ? ? ? ? ? ? ? ? ? ? ? ? DUMP key? ? ? ? ? ? ? ? ????????????????? 此命令返回存儲在指定鍵的值的序列化版本。

3? ? ? ? ? ? ? ? ? ? ? ? ? ?EXISTS key? ? ? ? ? ? ? ? ? ????????????????此命令檢查鍵是否存在。

4? ? ? ? ? ? ? ? ? ? ? ? ? ?EXPIRE key seconds? ? ????????????????設置鍵在指定時間秒數之后到期/過期。

5? ? ? ? ? ? ? ? ? ? ? ? ??EXPIREAT key timestamp? ????????????設置在指定時間戳之后鍵到期/過期。? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?這里的時間是Unix時間戳格式。

6????????????????????????PEXPIRE key milliseconds????????????????設置鍵的到期時間(以毫秒為單位)。

7????????????????????????PEXPIREAT key milliseconds-timestamp????以Unix時間戳形式來設置鍵的到期時間(以毫秒? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?????????????????????????????????為單位)。

8????????????????????????KEYS pattern????????????????????????????????????????????????查找與指定模式匹配的所有鍵。

9????????????????????????MOVE key db????????????????????????????????????????????????將鍵移動到另一個數據庫。

10????????????????????????PERSIST key????????????????????????????????????????????????刪除指定鍵的過期時間,得永生。

11????????????????????????PTTL key????????????????????????????????????????????????????????獲取鍵的剩余到期時間。

12????????????????????RANDOMKEY????????????????????????????????????????????????????從Redis返回一個隨機的鍵。

13????????????????????RENAME key newkey????????????????????????????????????????更改鍵的名稱。

14????????????????????PTTL key????????????????????????????????????????????????????????????獲取鍵到期的剩余時間(以毫秒為單位)。

15????????????????????RENAMENX key newkey????????????????????????????????????如果新鍵不存在,重命名鍵。

16????????????????????TYPE key????????????????????????????????????????????????????????????????返回存儲在鍵中的值的數據類型。

字符串命令

1、SET key value:此命令設置指定鍵的值。

2、GET key:獲取指定鍵的值。

3、GETRANGE key start end:獲取存儲在鍵上的字符串的子字符串。

4、GETSET key value:設置鍵的字符串值并返回其舊值。

5、GETBIT key offset:返回在鍵處存儲的字符串值中偏移處的位值。

6、MGET key1 [key2..]:獲取所有給定鍵的值

7、SETBIT key offset value:存儲在鍵上的字符串值中設置或清除偏移處的位

8、SETEX key seconds value:使用鍵和到期時間來設置值

9、SETNX key value:設置鍵的值,僅當鍵不存在時

10、SETRANGE key offset value:在指定偏移處開始的鍵處覆蓋字符串的一部分

11、STRLEN key:獲取存儲在鍵中的值的長度

12、MSET key value [key value …]:為多個鍵分別設置它們的值

13、MSETNX key value [key value …]:為多個鍵分別設置它們的值,僅當鍵不存在時

14、PSETEX key milliseconds value:設置鍵的值和到期時間(以毫秒為單位)

15、INCR key:將鍵的整數值增加1

16、INCRBY key increment:將鍵的整數值按給定的數值增加

17、INCRBYFLOAT key increment:將鍵的浮點值按給定的數值增加

18、DECR key:將鍵的整數值減1

19、DECRBY key decrement:按給定數值減少鍵的整數值

20、APPEND key value:將指定值附加到鍵

散列/哈希

Redis Hashes是字符串字段和字符串值之間的映射(類似于PHP中的數組類型)。 因此,它們是表示對象的完美數據類型。

1、HDEL key field2 [field2]:刪除一個或多個哈希字段。

2、HEXISTS key field:判斷是否存在散列字段。

3、HGET key field:獲取存儲在指定鍵的哈希字段的值。

4、HGETALL key:獲取存儲在指定鍵的哈希中的所有字段和值

5、HINCRBY key field increment:將哈希字段的整數值按給定數字增加

6、HINCRBYFLOAT key field increment:將哈希字段的浮點值按給定數值增加

7、HKEYS key:獲取哈希中的所有字段

8、HLEN key:獲取散列中的字段數量

9、HMGET key field1 [field2]:獲取所有給定哈希字段的值

10、HMSET key field1 value1 [field2 value2 ]:為多個哈希字段分別設置它們的值

11、HSET key field value:設置散列字段的字符串值

12、HSETNX key field value:僅當字段不存在時,才設置散列字段的值

13、HVALS key:獲取哈希中的所有值

列表

Redis列表只是字符串列表,按插入順序排序。可以在列表的頭部或尾部添加Redis列表中的元素。

列表的最大長度為2^32 - 1個元素(即4294967295,每個列表可存儲超過40億個元素)。

1、BLPOP key1 [key2 ] timeout:刪除并獲取列表中的第一個元素,或阻塞,直到有一個元素可用

2、BRPOP key1 [key2 ] timeout:刪除并獲取列表中的最后一個元素,或阻塞,直到有一個元素可用

3、BRPOPLPUSH source destination timeout:從列表中彈出值,將其推送到另一個列表并返回它; 或阻塞,直到一個可用

4、LINDEX key index:通過其索引從列表獲取元素

5、LINSERT key BEFORE/AFTER pivot value:在列表中的另一個元素之前或之后插入元素

6、LLEN key:獲取列表的長度

7、LPOP key:刪除并獲取列表中的第一個元素

8、LPUSH key value1 [value2]:將一個或多個值添加到列表

9、LPUSHX key value:僅當列表存在時,才向列表添加值

10、LRANGE key start stop:從列表中獲取一系列元素

11、LREM key count value:從列表中刪除元素

12、LSET key index value:通過索引在列表中設置元素的值

13、LTRIM key start stop:修剪列表的指定范圍

14、RPOP key:刪除并獲取列表中的最后一個元素

15、RPOPLPUSH source destination:刪除列表中的最后一個元素,將其附加到另一個列表并返回

16、RPUSH key value1 [value2]:將一個或多個值附加到列表

17、RPUSHX key value:僅當列表存在時才將值附加到列表

集合

Redis集合是唯一字符串的無序集合。唯一值表示集合中不允許鍵中有重復的數據。

在Redis中設置添加,刪除和測試成員的存在(恒定時間O(1),而不考慮集合中包含的元素數量)。列表的最大長度為2^32 - 1個元素(即4294967295,每組集合超過40億個元素)。

1、SADD key member1 [member2]:將一個或多個成員添加到集合

2、SCARD key:獲取集合中的成員數

3、SDIFF key1 [key2]:減去多個集合(求差集)

4、SDIFFSTORE destination key1 [key2]:減去多個集并將結果集存儲在鍵中

5、SINTER key1 [key2]:相交多個集合(求交集)

6、SINTERSTORE destination key1 [key2]:交叉多個集合并將結果集存儲在鍵中

7、SISMEMBER key member:判斷確定給定值是否是集合的成員

8、SMOVE source destination member:將成員從一個集合移動到另一個集合

9、SPOP key:從集合中刪除并返回隨機成員

10、SRANDMEMBER key [count]:從集合中獲取一個或多個隨機成員

11、SREM key member1 [member2]:從集合中刪除一個或多個成員

12、SUNION key1 [key2]:添加多個集合

13、SUNIONSTORE destination key1 [key2]:添加多個集并將結果集存儲在鍵中

14、SSCAN key cursor [MATCH pattern] [COUNT count]:遞增地迭代集合中的元素

15、SMEMBERS key:遍歷整個集合

可排序集合

Redis可排序集合類似于Redis集合,是不重復的字符集合。 不同之處在于,排序集合的每個成員都與分數相關聯,這個分數用于按最小分數到最大分數來排序的排序集合。雖然成員是唯一的,但分數值可以重復。

1、ZADD key score1 member1 [score2 member2]:向有序集合添加一個或多個成員,或者更新已存在成員的分數

2、ZCARD key:獲取有序集合的成員數

3、ZCOUNT key min max:?計算在有序集合中指定區(qū)間分數的成員數

4、ZINCRBY key increment member:有序集合中對指定成員的分數加上增量 increment

5、ZINTERSTORE destination numkeys key [key ...]:計算給定的一個或多個有序集的交集并將結果集存儲在新的有序集合 key 中

6、ZLEXCOUNT key min max:?在有序集合中計算指定字典區(qū)間內成員數量

7、ZRANGE key start stop [WITHSCORES]:通過索引區(qū)間返回有序集合成指定區(qū)間內的成員

8、ZRANGEBYLEX key min max [LIMIT offset count]:通過字典區(qū)間返回有序集合的成員

9、ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT]:通過分數返回有序集合指定區(qū)間內的成員

10、ZRANK key member:返回有序集合中指定成員的索引

11、ZREM key member [member ...]:移除有序集合中的一個或多個成員

12、ZREMRANGEBYLEX key min max:移除有序集合中給定的字典區(qū)間的所有成員

13、ZREMRANGEBYRANK key start stop:?移除有序集合中給定的排名區(qū)間的所有成員

14、ZREMRANGEBYSCORE key min max:移除有序集合中給定的分數區(qū)間的所有成員

15、ZREVRANGE key start stop [WITHSCORES]:返回有序集中指定區(qū)間內的成員,通過索引,分數從高到底

16、ZREVRANGEBYSCORE key max min [WITHSCORES]:返回有序集中指定分數區(qū)間內的成員,分數從高到低排序

17、ZREVRANK key member:?返回有序集合中指定成員的排名,有序集成員按分數值遞減(從大到小)排序

18、ZSCORE key member:返回有序集中,成員的分數值

19、ZUNIONSTORE destination numkeys key [key ...]:計算給定的一個或多個有序集的并集,并存儲在新的 key 中

20、ZSCAN key cursor [MATCH pattern] [COUNT count]:迭代有序集合中的元素(包括元素成員和元素分值)

HyperLogLog

Redis 在 2.8.9 版本添加了 HyperLogLog 結構。

Redis HyperLogLog 是用來做基數統計的算法,HyperLogLog 的優(yōu)點是,在輸入元素的數量或者體積非常非常大時,計算基數所需的空間總是固定 的、并且是很小的。

在 Redis 里面,每個 HyperLogLog 鍵只需要花費 12 KB 內存,就可以計算接近 2^64 個不同元素的基 數。這和計算基數時,元素越多耗費內存就越多的集合形成鮮明對比。

但是,因為 HyperLogLog 只會根據輸入元素來計算基數,而不會儲存輸入元素本身,所以 HyperLogLog 不能像集合那樣,返回輸入的各個元素。

什么是基數?

比如數據集 {1, 3, 5, 7, 5, 7, 8}, 那么這個數據集的基數集為 {1, 3, 5 ,7, 8}, 基數(不重復元素)為5。 基數估計就是在誤差可接受的范圍內,快速計算基數。

1、PFADD key element [element ...]:添加指定元素到 HyperLogLog 中。

2、PFCOUNT key [key ...]:返回給定 HyperLogLog 的基數估算值。

3、PFMERGE destkey sourcekey [sourcekey ...]:將多個 HyperLogLog 合并為一個 HyperLogLog

作者:誰在烽煙彼岸

鏈接:http://www.itdecent.cn/p/d74c9fee9a52

來源:簡書

著作權歸作者所有。商業(yè)轉載請聯系作者獲得授權,非商業(yè)轉載請注明出處。

?著作權歸作者所有,轉載或內容合作請聯系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容