1、Redis 键(key)
- Redis 键命令用于管理 redis 的键。
| 命令 | 描述 | 示例 |
|---|---|---|
| DEL key | 用于删除某个key | DEL k1 |
| DUMP key | 序列化指定key并返回序列化之后的值 | DUMP k1 |
| EXISTS key | 检测key是否存在 | EXISTS k1 |
| PEXPIRE key milliseconds | 设置key的过期时间以毫秒计 | PEXPIRE k1 30 |
| KEYS pattern | 查找所有符合(pattern)的key | keys * |
| MOVE key db | 将当前key移动到指定db中 | MOVE k1 2 |
| PERSIST key | 移除key的过期时间 | PERSIST k1 |
| PTTL key | 以毫秒为单位返回key的剩余过期时间 | PTTL k1 |
| TTL key | 以秒为单位,返回给定 key 的剩余生存时间 | TTL k1 |
| RANDOMKEY | 从当前DB随机返回一个key | RANDOMKEY |
| RENAME key newkey | 修改key名称 | RENAME k1 k2 |
| RENAMENX key newkey | 当 newkey 不存在时,将 key 改名为 newkey 。 | RENAMENX k1 k3 |
| TYPE key | 返回key所储存值的类型 | type k2 |
2、Redis 字符串(String)
- 用于管理 redis 字符串值
| 命令 | 描述 | 示例 |
|---|---|---|
| SET key value | 设置指定 key 的值 | SET ks 123456789 |
| GET key | 获取指定key的值 | GET ks |
| GETRANGE key start end | 返回 key 中字符串值的子字符 | GETRANGE ks 1 5 |
| GETSET key value | 将给定 key 的值设为 value ,并返回 key 的旧值 | GETSET ks 5555 |
| GETBIT key offset | 对 key 所储存的字符串值,获取指定偏移量上的位(bit) | GETBIT ks 10000 |
| MGET key1 [key2…] | 获取所有(一个或多个)给定 key 的值 | MGET k1 k2 k3 |
| SETBIT key offset value | 对 key 所储存的字符串值,设置或清除指定偏移量上的位(bit) | SETBIT ks 10000 1 |
| SETEX key seconds value | 将值 value 关联到 key ,并将 key 的过期时间设为 seconds (以秒为单位) | SETEX k0 30 Hello,Redis |
| SETNX key value | 只有在 key 不存在时设置 key 的值 | SETNX ks 8520 |
| SETRANGE key offset value | 用 value 参数覆写给定 key 所储存的字符串值,从偏移量 offset 开始 | SETRANGE ks 5 redis |
| STRLEN key | 返回key所存储的字符串值的长度 | STRLEN ks |
| MSET key value [key value …] | 同时设置一个或多个key-value对 | MSET k1 1111 k2 222 k3 333 |
| MSETNX key value [key value …] | 同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在 | MSETNX k5 555 k6 666 |
| PSETEX key milliseconds value | 以毫秒为单位设置 key 的生存时间 | PSETEX k5 5000 |
| INCR key | 将 key 中储存的数字值增加1 | INCR k6 |
| INCRBY key increment | 将 key 所储存的值加上给定的增量值(increment) | INCRBY k6 8 |
| INCRBYFLOAT key increment | 将 key 所储存的值加上给定的浮点增量值(increment) | INCRBYFLOAT k6 1.5 |
| DECR key | 将 key 中储存的数字值减一 | DECR k6 |
| DECRBY key decrement | key 所储存的值减去给定的减量值(decrement) | DECRBY k6 4 |
| APPEND key value | 如果 key 已经存在并且是一个字符串, APPEND 命令将指定的 value 追加到该 key 原来值(value)的末尾 | APPEND ks 101112 |
3、Redis 列表(List)
- Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。
| 命令 | 描述 | 示例 |
|---|---|---|
| LPUSH key value1 [value2] | 将一个或多个值插入到列表头部 | LPUSH lis1 1 2 3 4 5 6 |
| LPUSHX key value | 将一个值插入到已存在的列表头部 | LPUSHX lis1 8 |
| LRANGE key start stop | 获取列表指定范围内的元素 | LRANGE lis1 0 -1 |
| LREM key count value | 移除列表中指定count的value值 | LREM lis1 5 5 |
| LSET key index value | 通过索引设置列表元素的值 | LSET lis1 0 8888 |
| LTRIM key start stop | 对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除 | LTRIM lis1 5 8 |
| RPOP key | 移除列表的最后一个元素,返回值为移除的元素 | RPOP lis1 |
| RPOPLPUSH source destination | 移除列表的最后一个元素,并将该元素添加到另一个列表并返回 | RPOPLPUSH lis1 lis2 |
| RPUSH key value1 [value2] | 将一个或多个值插入到列表尾部 | RPUSH lis2 1 2 3 4 5 6 |
| RPUSHX key value | 将一个值插入到已存在的列表头部 | RPUSHX lis2 8 |
| BLPOP key1 [key2 ] timeout | 移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止 | BLPOP lis2 5 |
| BRPOP key1 [key2 ] timeout | 移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止 | BRPOP lis2 2 |
| BRPOPLPUSH source destination timeout | 从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止 | BRPOPLPUSH lis1 lis2 5 |
| LINDEX key index | 通过索引获取列表中的元素 | LINDEX lis1 2 |
| LINSERT key BEFORE | AFTER pivot value | 将值 value 插入到列表 key 当中,位于值 pivot 之前或之后。 |
| LLEN key | 获取列表长度 | LITM lis1 |
| LPOP key | 移出并获取列表的第一个元素 | LPOP lis1 |
4、Redis 集合(Set)
- Redis 的 Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
- Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。
- 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
| 命令 | 描述 | 示例 |
|---|---|---|
| SADD key member1 [member2] | 向集合添加一个或多个成员 | SADD s1 121 122 122 135 156 8546 422 |
| SCARD key | 获取集合的成员数 | SCARD s1 |
| SDIFF key1 [key2] | 返回给定所有集合的差集 | SIFF s1 s2 |
| SDIFFSTORE destination key1 [key2] | 返回给定所有集合的差集并存储在 destination 中 | SDIFFSTORE sc s1 s2 |
| SINTER key1 [key2] | 返回给定所有集合的交集 | SINTER s1 s2 |
| SINTERSTORE destination key1 [key2] | 返回给定所有集合的交集并存储在 destination 中 | SINTERSTORE sc s1 s2 |
| SISMEMBER key member | 判断 member 元素是否是集合 key 的成员 | SISMEMBER s1 422 |
| SMEMBERS key | 返回集合中的所有成员 | SMEMBERS s1 |
| SMOVE source destination member | 将 member 元素从 source 集合移动到 destination 集合 | SMOVE s1 s2 135 |
| SPOP key | 移除并返回集合中的一个随机元素 | SPOP s1 |
| SRANDMEMBER key [count] | 返回集合中一个或多个随机数 | SRANDMEMBER s12 |
| SREM key member1 [member2] | 移除集合中一个或多个成员 | SREM s1 121 122 |
| SUNION key1 [key2] | 返回所有给定集合的并集 | SUNION s1 s2 |
| SUNIONSTORE destination key1 [key2] | 所有给定集合的并集存储在 destination 集合中 | SUNIONSTORE sb s1 s2 |
| SSCAN key cursor [MATCH pattern] [COUNT count] | 迭代集合中的元素 | SSCAN s1 0 match 12* |
5、Redis 哈希(Hash)
- Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。
- Redis 中每个 hash 可以存储 232 - 1 键值对(40多亿)。
| 命令 | 描述 | 示例 |
|---|---|---|
| HMSET key field1 value1 [field2 value2 ] | 同时将多个 field-value (域-值)对设置到哈希表 key 中 | HMSET user name z3 age 28 salary 8000 |
| HMGET key field1 [field2] | 获取所有给定字段的值 | HMGET user name age salary |
| HSET key field value | 将哈希表 key 中的字段 field 的值设为 value | HSET user name li4 |
| HSETNX key field value | 只有在字段 field 不存在时,设置哈希表字段的值 | HSETNX user email xxxx@163.com |
| HVALS key | 获取哈希表中所有值 | HVALS user |
| HDEL key field1 [field2] | 删除一个或多个哈希表字段 | HDEL user name age |
| HEXISTS key field | 查看哈希表 key 中,指定的字段是否存在 | HEXISTS user name |
| HGET key field | 获取存储在哈希表中指定字段的值 | HGET user name |
| HGETALL key | 获取在哈希表中指定 key 的所有字段和值 | HGETALL user |
| HINCRBY key field increment | 为哈希表 key 中的指定字段的整数值加上增量 increment | HINCRBY user age 2 |
| HINCRBYFLOAT key field increment | 为哈希表 key 中的指定字段的浮点数值加上增量 increment | HINCRBYFLOAT user salary 1945.52 |
| HKEYS key | 获取所有哈希表中的字段 | HKEYS user |
| HLEN key | 获取哈希表中字段的数量 | HLEN user |
6、Redis 有序集合(sorted set)
- Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。
- 不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
有序集合的成员是唯一的,但分数(score)却可以重复。 - 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
| 命令 | 描述 | 示例 |
|---|---|---|
| ZADD key score1 member1 [score2 member2] | 向有序集合添加一个或多个成员,或者更新已存在成员的分数 | ZADD zs1 60 v1 70 v2 80 v3 90 v4 100 v5 |
| ZCARD key | 获取有序集合的成员数 | ZCARD zs1 |
| ZCOUNT key min max | 计算在有序集合中指定区间分数的成员数 | ZCOUNT zs1 60 80 |
| ZINCRBY key increment member | 有序集合中对指定成员的分数加上增量 increment | ZINCRBY zs1 50 v5 |
| ZINTERSTORE destination numkeys key [key …] | 计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中 | ZINTERSTORE zs_sum 2 zs1 zs2 |
| ZLEXCOUNT key min max | 在有序集合中计算指定字典区间内成员数量 | ZLEXCOUNT zs1 v3 v5 |
| ZRANGE key start stop [WITHSCORES] | 通过索引区间返回有序集合成指定区间内的成员 | ZRANGE zs1 0 -1 / ZRANGE zs1 0 -1 WITHSCORES |
| ZRANGEBYLEX key min max [LIMIT offset count] | 通过字典区间返回有序集合的成员 | ZLEXCOUNT zs1 - + / ZLEXCOUNT zs1 [d [z |
| ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] | 通过分数返回有序集合指定区间内的成员 | ZRANGEBYSCORE zs1 60 100 LIMIT 2 / ZRANGEBYSCORE zs1 60 100 withscores limit 5 |
| ZRANK key member | 返回有序集合中指定成员的索引 | ZRANK zs1 v5 |
| ZREM key member [member …] | 移除有序集合中的一个或多个成员 | ZREM zs1 v2 v5 |
| ZREMRANGEBYLEX key min max | 移除有序集合中给定的字典区间的所有成员 | ZREMRANGEBYLEX zs1 [x [z |
| ZREMRANGEBYRANK key start stop | 移除有序集合中给定的排名区间的所有成员 | ZREMRANGEBYRANK zs1 v4 v5 |
| ZREMRANGEBYSCORE key min max | 移除有序集合中给定的分数区间的所有成员 | ZREMRANGEBYSCORE zs1 60 80 |
| ZREVRANGE key start stop [WITHSCORES] | 返回有序集中指定区间内的成员,通过索引,分数从高到底 | ZREVRANGE zs1 0 -1 withscores |
| ZREVRANGEBYSCORE key max min [WITHSCORES] | 返回有序集中指定分数区间内的成员,分数从高到低排序 | ZREVRANGEBYSCORE zs1 90 70 |
| ZREVRANK key member | 返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序 | ZREVRANK zs1 v5 |
| ZSCORE key member | 返回有序集中,成员的分数值 | ZSCORE zs1 80 |
| ZUNIONSTORE destination numkeys key [key …] | 计算给定的一个或多个有序集的并集,并存储在新的 key 中 | ZUNIONSTORE scs 2 zs1 zs2 |
来源:CSDN
作者:战·后风!!
链接:https://blog.csdn.net/weixin_44187730/article/details/94594592