专栏首页earthchen的专栏Redis学习笔记 -- 2

Redis学习笔记 -- 2

接着上一篇接着介绍redis的知识

Redis

Redis 键(key)

Redis 键命令用于管理 redis 的键。

  1. 语法 127.0.0.1:6379> COMMAND KEY_NAME
  2. 实例 127.0.0.1:6379> SET w3ckey redis OK 127.0.0.1:6379> DEL w3ckey (integer) 1 DEL 是一个命令, w3ckey 是一个键。 如果键被删除成功,命令执行后输出 (integer) 1,否则将输出 (integer) 0 Redis keys 相关命令

命令

描述

DEL key

在 key 存在是删除 key

DUMP key

序列化给定 key ,并返回被序列化的值

EXISTS key

检查给定 key 是否存在

EXPIRE key seconds

给定 key 设置过期时间

EXPIREAT key timestamp

EXPIREAT 的作用和 EXPIRE 类似,都用于为 key 设置过期时间。 不同在于 EXPIREAT 命令接受的时间参数是 UNIX 时间戳(unix timestamp)

KEYS pattern

查找所有符合给定模式( pattern)的 key

MOVE key db

将当前数据库的 key 移动到给定的数据库 db 当中

PERSIST key

移除 key 的过期时间,key 将持久保持

PTTL key

以毫秒为单位返回 key 的剩余的过期时间

RENAME key newkey

修改 key 的名称

RENAMENX key newkey

仅当 newkey 不存在时,将 key 改名为 newkey

TYPE key

返回 key 所储存的值的类型

Redis 字符串(String)

Redis 字符串数据类型的相关命令用于管理 redis 字符串值,基本语法如下:

  1. 语法 127.0.0.1:6379> COMMAND KEY_NAME
  2. 实例 127.0.0.1:6379> SET w3ckey redis OK 127.0.0.1:6379> GET w3ckey "redis" SET 和 GET 命令,键为 w3ckey。 DEL 是一个命令, w3ckey 是一个键。 如果键被删除成功,命令执行后输出 (integer) 1,否则将输出 (integer) 0 Redis keys 相关命令

命令

描述

SET key value

设置指定 key 的值

GET key

获取指定 key 的值

GETRANGE key start end

返回 key 中字符串值的子字符

GETSET key value

将给定 key 的值设为 value ,并返回 key 的旧值(old value)

GETBIT key offset

对 key 所储存的字符串值,获取指定偏移量上的位(bit)

MGET key1 [key2..]

获取所有(一个或多个)给定 key 的值

SETEX key seconds value

将值 value 关联到 key ,并将 key 的过期时间设为 seconds (以秒为单位)

SETNX key value

只有在 key 不存在时设置 key 的值

STRLEN key

返回 key 所储存的字符串值的长度

MSET key value [key value …]

同时设置一个或多个 key-value 对

INCR key

将 key 中储存的数字值增一

NCRBY key increment

将 key 所储存的值加上给定的增量值(increment)

NCRBYFLOAT key increment

将 key 所储存的值加上给定的浮点增量值(increment)

DECR key

将 key 中储存的数字值减一

DECRBY key decrement

key所储存的值减去给定的减量值(decrement

APPEND key value

如果 key 已经存在并且是一个字符串, APPEND 命令将 value 追加到 key 原来的值的末尾

Redis 哈希(Hash)

Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。。

  1. 实例
127.0.0.1:6379>HMSET w3ckey name "redis tutorial" description "redis basic commands for caching" likes 20 visitors 2300
OK
127.0.0.1:6379> HGETALL w3ckey
1) "name"
2) "redis tutorial"
3) "description"
4) "redis basic commands for caching"
5) "likes"
6) "20"
7) "visitors"
8) "23000"

设置了 redis 的一些描述信息(name, description, likes, visitors) 到哈希表的 w3ckey 中。

Redis hash 命令

命令

描述

HDEL key field2 [field2]

删除一个或多个哈希表字段

HEXISTS key field

查看哈希表 key 中,指定的字段是否存在

HGET key field

获取存储在哈希表中指定字段的值

HGETALL key

获取在哈希表中指定 key 的所有字段和值

HINCRBY key field increment

为哈希表 key 中的指定字段的整数值加上增量 increment

HINCRBYFLOAT key field increment

为哈希表 key 中的指定字段的浮点数值加上增量 increment

HKEYS key

获取所有哈希表中的字段

HLEN key

获取哈希表中字段的数量

HMGET key field1 [field2]

获取所有给定字段的值

HMSET key field1 value1 [field2 value2 ]

同时将多个 field-value (域-值)对设置到哈希表 key 中

HSETNX key field value

只有在字段 field 不存在时,设置哈希表字段的值。

HVALS key

获取哈希表中所有值

HSCAN key cursor [MATCH pattern] [COUNT count]

迭代哈希表中的键值对

Redis 列表(List)

Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素导列表的头部(左边)或者尾部(右边

  1. 实例
127.0.0.1:6379>LPUSH w3ckey redis
(integer) 1
127.0.0.1:6379> LPUSH w3ckey mongodb
(integer) 2
127.0.0.1:6379> LPUSH w3ckey mysql
(integer) 3
127.0.0.1:6379> LRANGE w3ckey 0 10
1) "mysql"
2) "mongodb"
3) "redis"

Redis 列表命令

命令

描述

BLPOP key1 [key2 ] timeout

移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止

BRPOP key1 [key2 ] timeout

移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止

BRPOPLPUSH source destination timeout

从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止

LINDEX key index

通过索引获取列表中的元素

**LINSERT key BEFORE

AFTER pivot value**

在列表的元素前或者后插入元素

LLEN key

获取列表长度

LPOP key

移出并获取列表的第一个元素

LPUSH key value1 [value2]

将一个或多个值插入到列表头部

LPUSHX key value

将一个或多个值插入到已存在的列表头部

LRANGE key start stop

获取列表指定范围内的元素

LREM key count value

移除列表元素

LSET key index value

通过索引设置列表元素的值

LTRIM key start stop

对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除

RPOP key

移除并获取列表最后一个元素

RPOPLPUSH source destination

移除列表的最后一个元素,并将该元素添加到另一个列表并返回

RPUSH key value1 [value2]

在列表中添加一个或多个值

RPUSHX key value

为已存在的列表添加值

Redis 集合(Set)

Redis的Set是string类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据

  1. 实例
 127.0.0.1:6379> SADD redis redis
(integer) 1
127.0.0.1:6379> SADD redis mongo
(integer) 1
127.0.0.1:6379> SADD redis rebitmq
(integer) 1
127.0.0.1:6379> SADD redis rebitmq
(integer) 0
127.0.0.1:6379> ZRANGEBYSCORE redis 0 1000
1) "mongo"
2) "rabitmq"
3) "redis"

Redis 集合命令

命令

描述

SADD key member1 [member2]

向集合添加一个或多个成员

SCARD key

获取集合的成员数

SDIFF key1 [key2]

返回给定所有集合的差集

SINTER key1 [key2]

返回给定所有集合的交集

SISMEMBER key member

判断 member 元素是否是集合 key 的成员

SMEMBERS key

返回集合中的所有成员

SMOVE source destination member

将 member 元素从 source 集合移动到 destination 集合

SPOP key

移除并返回集合中的一个随机元素

SUNION key1 [key2]

返回所有给定集合的并集

SSCAN key cursor [MATCH pattern] [COUNT count]

迭代集合中的元素

Redis 有序集合(sorted set)

Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。 不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。 有序集合的成员是唯一的,但分数(score)却可以重复。

  1. 实例
127.0.0.1:6379> ZADD w3ckey 1 redis
(integer) 1
127.0.0.1:6379> ZADD w3ckey 2 mongodb
(integer) 1
127.0.0.1:6379> ZADD w3ckey 3 mysql
(integer) 1
127.0.0.1:6379> ZADD w3ckey 3 mysql
(integer) 0
127.0.0.1:6379> ZADD w3ckey 4 mysql
(integer) 0
127.0.0.1:6379> ZRANGE w3ckey 0 10 WITHSCORES
 
1) "redis"
2) "1"
3) "mongodb"
4) "2"
5) "mysql"
6) "4"

Redis 有序集合命令

命令

描述

ZADD key score1 member1 [score2 member2]

向有序集合添加一个或多个成员,或者更新已存在成员的分数

ZCARD key

获取有序集合的成员数

ZCOUNT key min max

计算在有序集合中指定区间分数的成员数

ZLEXCOUNT key min max

在有序集合中计算指定字典区间内成员数量

ZRANGE key start stop [WITHSCORES]

通过索引区间返回有序集合成指定区间内的成员

ZRANGEBYLEX key min max [LIMIT offset count]

通过字典区间返回有序集合的成员

ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT]

通过分数返回有序集合指定区间内的成员

ZRANK key member

返回有序集合中指定成员的索引

ZREM key member [member …]

移除有序集合中的一个或多个成员

ZREMRANGEBYLEX key min max

移除有序集合中给定的字典区间的所有成员

ZREMRANGEBYRANK key start stop

移除有序集合中给定的排名区间的所有成员

ZREMRANGEBYSCORE key min max

移除有序集合中给定的分数区间的所有成员

ZSCORE key member

返回有序集中,成员的分数值

ZUNIONSTORE destination numkeys key [key …]

计算给定的一个或多个有序集的并集,并存储在新的 key 中

ZSCAN key cursor [MATCH pattern] [COUNT count]

迭代有序集合中的元素(包括元素成员和元素分值)

注:

  • 上述环境在ubuntu16.04 lts中测试成功
  • 上述文字皆为个人看法,如有错误或建议请及时联系我

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • django+nginx+gunicorn部署配置

    在部署django开发的站点时,通常有两种选择方式,nginx+django+uwsgi或者django+nginx+gunicorn,本文不讨论apache方...

    用户1637228
  • Django操作数据库

    本篇主要介绍我们在使用django框架开发的时候使用的操作数据库的语句,这在动态网站部分是很重要的,因为我们需要连接数据库进行操作,然后把数据处理的结果显示在前...

    用户1637228
  • java面试知识要点汇总(线程和锁)

    实现Runnable和实现Callable接口的方式基本相同,不过是后者执行call()方法有返回值,后者线程执行体run()方法无返回值,因此可以把这两种方式...

    用户1637228
  • 开发人员必备Redis知识点基础命令键命令string命令hash结构listset结构sorted set

    JavaEdge
  • 如何处理redis集群的hot key和big key

    redis 集群部署方式大部分采用类 Twemproxy 的方式进行部署。即通过 Twemproxy 对 redis key 进行分片计算,将 redis ke...

    akayzhang
  • Java 快速排序 关于起始方向的选择问题 为什么一定要从右边开始

    最后i、j 停留的位置的值肯定是要 小于 key 的 此时交换索引 j 和最左边元素key 符合将小于key的值放到key左边这一条件

    heasy3
  • 在微博微信场景下学习Redis数据结构

    这个是微信公众号的文章阅读量数量的统计,可以通过redis的string数据结构来解决。使用incr原子操作命令,redis的key是article:readc...

    程序员小强
  • Redis学习二(数据操作).

    在 redis-cli 中使用中文时,必须打开 --raw 选项,才能正常显示中文。

    JMCui
  • redis数据结构、持久化、缓存淘汰策略

    Redis 单线程高性能,它所有的数据都在内存中,所有的运算都是内存级别的运算,而且单线程避免了多线程的切换性能损耗问题。redis利用epoll来实现IO多路...

    业余草

扫码关注云+社区

领取腾讯云代金券