大数据求索(13): Redis数据类型详解

大数据求索(13): Redis数据类型详解

一、Redis五大数据类型

Redis总共有五大数据类型,分别包括以下内容:

  • String(字符串)
  • Hash(哈希)
  • List(列表)
  • Set(集合)
  • ZSet(有序集合)

丰富的数据类型使得Redis能够在非常多的场景下发挥巨大的作用,下面对这五种数据类型分别作详细介绍。

二、String

2.1 重要概念

String是redis最基本的类型,你可以理解成与Memcached一模一样的类型(Memcached只支持String),一个key对应一个value,是单值单value的

String类型是二进制安全(类似java中的序列化)的。意思是redis的string可以包含任何数据,比如jpg图片或者序列化的对象 。

String类型是Redis最基本的数据类型,一个String中字符串value最多可以是512M

2.2 核心命令

  • set/get/del/append/strlen

  • Incr/decr/incrby/decrby, 一定要是数字才能进行加减

  • getrange/setrange

    • getrange:获取指定区间范围内的值,类似between…and的关系,从零到负一表示全部

大数据求索(13): Redis数据类型详解_第1张图片

  • setrange设置指定区间范围内的值,格式是setrange key值 具体值

    1545701114403

  • setex(set with expire) 键秒值/setnx(set if not exist)

    • setex:设置带过期时间的key,动态设置。setex 键 秒值 真实值
      大数据求索(13): Redis数据类型详解_第2张图片
    • setnx:只有在 key 不存在时设置 key 的值。

    大数据求索(13): Redis数据类型详解_第3张图片

  • mset/mget/msetnx

    • mset:同时设置一个或多个 key-value 对。

      大数据求索(13): Redis数据类型详解_第4张图片

    • mget:获取所有(一个或多个)给定 key 的值。

      大数据求索(13): Redis数据类型详解_第5张图片

  • getset(先get再set)

    getset:将给定 key 的值设为 value ,并返回 key 的旧值(old value)。
    简单一句话,先get然后立即set

    大数据求索(13): Redis数据类型详解_第6张图片

三、List

3.1 重要概念

Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素导列表的头部(左边)或者尾部(右边)。
它的底层实际是个链表,相当于Java中的LinkedList

3.2 核心命令

  • lpush/rpush/lrange

  • lpop/rpop 左边弹出一个值/右边弹出一个值,类似栈操作

  • lindex,按照索引下标获得元素(从上到下)

  • llen

  • lrem key N v1 解释(删除N个值等于v1的元素)

    • 从left往right删除2个值等于v1的元素,返回的值为实际删除的数量

    • LREM list3 0 值,表示删除全部给定的值。零个就是全部值

      大数据求索(13): Redis数据类型详解_第7张图片

  • ltrim key 开始index 结束index,截取指定范围的值后再赋值给key

    大数据求索(13): Redis数据类型详解_第8张图片

  • rpoplpush 源列表 目的列表

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

  • lset key index value

    设置指定索引处的值,index不能越界

  • linsert key before/after 已有值 插入的新值

    在list某个已有值的前后再添加具体值

    大数据求索(13): Redis数据类型详解_第9张图片

3.3 性能总结

它是一个字符串链表,left、right都可以插入添加;
如果键不存在,创建新的链表;
如果键已存在,新增内容;
如果值全移除,对应的键也就消失了。

它的底层实际是个双向链表,对两端的操作性能很高,通过索引下标的操作中间的节点性能会较差。

大数据求索(13): Redis数据类型详解_第10张图片

四、Hash

4.1 重要概念

Redis hash 是一个键值对集合。
Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。KV模式不变,但V是一个键值对

类似Java里面的Map

4.2 核心命令

  • hset/hget/hmset/hmget/hgetall/hdel/hlen

  • hexists key 在key里面的某个值的key

  • hkeys/hvals key 返回某个key下面所有的keys/values

  • hincrby/hincrbyfloat

    大数据求索(13): Redis数据类型详解_第11张图片

  • hsetnx

五、Set

5.1 重要概念

Redis的Set是string类型的无序无重复集合。它是通过HashTable实现实现的。

是单值多value

5.2 核心命令

  • sadd/smembers/sismember
  • scard,获取集合里面的元素个数
  • srem key value 删除集合中元素
  • srandmember key 某个整数(随机出几个数)
  • spop key 随机出栈
  • smove key1 key2 在key1里某个值 作用是将key1里已存在的某个值赋给key2
  • 数学集合类
    • 差集:sdiff
    • 交集:sinter
    • 并集:sunion

六、ZSet

6.1 重要概念

Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。

不同的是每个元素都会关联一个double类型的分数。

redis正是通过分数来为集合中的成员进行从小到大的排序。zset的成员是唯一的,但分数(score)却可以重复。

相当于在set基础上,加一个score值。
之前set是k1 v1 v2 v3,
现在zset是k1 score1 v1 score2 v2

6.2 核心命令

  • zadd/zrange [withscores]

  • zrangebyscore key 开始score 结束score

  • withscores

  • ( 不包含

  • Limit 作用是返回限制 limit 开始下标步 多少步

大数据求索(13): Redis数据类型详解_第12张图片

  • zrem key 某score下对应的value值,作用是删除元素

  • zcard key

  • zcount key score区间

  • zrank key values值,作用是获得下标值

  • zscore key 对应值,获得分数

  • zrevrank key values值,作用是逆序获得下标值

  • zrevrange

  • zrevrangebyscore key 结束score 开始score 获得 逆序范围score内的值

七、其他重要知识

  • redis是单进程的
  • 默认16个数据库,类似数组下表从零开始,初始默认使用零号库
  • select命令切换数据库
  • dbsize查看当前数据库的key的数量
  • flushdb:清空当前库
  • flushall: 通杀全部库
  • 统一密码管理,16个库都是同样密码,要么都OK要么一个也连接不上
  • Redis索引都是从零开始
  • 默认端口是6379

八、参考

  1. 尚学堂Redis

你可能感兴趣的:(A大数据开发,大数据求索,redis)