Redis的数据结构

五种数据类型:

  字符串(String)、字符串列表(list)、字符串集合(set)、有序字符串集合(sorted set)、哈希(hash)

key定义的注意点:

  • 不要过长,不要超过1024个字节
  • 不要过短,会降低可读性
  • 要有统一的命名规范

存储String

二进制的方式存储的,意味着该类型存入和获取的数据是相同的,value最多容纳的数据长度

  • 存储String常用命令:

    • 赋值set、
    • 取值get(getset)、
    • 删除del、
    • 扩展[incrby(将value加指定值),decrby自减]、
    • 数据增减[incr(若没有则设初始值0,再数值增1;字符串会异常),decr自减1]
    • 追加append,返回字符串长度

存储Hash

String key和String Value的map容器,每个Hashkey最多存储4294967295个键值对

  • 常用命令:

    • 赋值 hset myhash username cui
    • 多个赋值 hmset myhash username cui age 24
    • 取值 hget myhash username
    • 多个取值 hmget myhash username age
    • 获取全部值 hgetall myhash
    • 删除多个 hdel myhash username age
    • 删除整个集合 del myhash
    • 增加 hincrby myhash age 5
    • 判断值是否存在 hexists myhash username
    • 获取值的数量hlen myhash
    • 获取所有属性名称 hkeys myhash
    • 获取所有属性的值 hvals myhash

存储list

ArrayList使用数组方式,LinkedList使用双向链表方式,双向链表中增加数据、删除数据

  • 常用命令:

    • 两端添加

      • lpush mylist a b c
      • rpush mylist 1 2 3
    • 查看列表
      • lrange mylist 0 -1(查看全部)
    • 两端弹出
      • lpop mylist (弹出第一个元素,就没有此元素了)
      • rpop mylist
    • 获取列表元素个数
      • llen mylist
    • 扩展命令
      • lpushx mylist 3 (仅当mylist存在时插入)
      • rpushx mylist 3
    • lrem mylist count value
      (count>0:从头删除count个值为value的元素
      count=0: 删除所有等于value的元素
      count<0:从尾开始删除count个等于value的元素)
    • 设置下标插入 lset mylist 3 mm(在3位置插入mm)
    • 设置在某元素前后插入linsert mylist before|after b 11(在b前或后插入11)
    • 将一个list的尾弹出压入另一个list头(rpoplpush mylist1 mylist2)

rpoplpush使用场景:

  消息队列发布系统时,对其进行备份

存储Set

没有排序的字符集合,不允许出现重复set可包含最大元素数量是4294967295个

  • 常用命令:

    • 添加/删除元素

      • sadd myset a b c
      • srem myset b c
    • 获取集合中的元素
      • smembers myset
    • 集合中的差集运算
      • sdiff myset1 myset2
    • 集合中的交集运算
      • sinter myset1 myset2
    • 集合中的并集运算
      • sunion myset1 myset2
    • 扩展命令
      • 判断是否有指定的值sismember myset c
      • 查看set中的元素数量 scard myset
      • 返回set中的随机一个元素 srandmember myset
      • 将两个set中相差的元素存入新的集合 sdiffstore myset3 myset1 myset2 (存入myset3)
      • 将两个set中交集的元素存入新的集合 sinterstore myset3 myset1 myset2
      • 将两个set中并集的元素存入新的集合sunionstore myset3 myset1 myset2

set使用场景:

  • 跟踪具有唯一性的数据:访问某一博客的唯一ip地址
  • 维护数据对象之间的关联关系

存储Sorted-Set

Sorted-Set和Set的区别

    Sorted-Set每个成员都有一个分数(可以重复)与之关联,Redis中用来从小到大的排序。

    时间复杂度为集合中成员的个数的对数

    Sorted-Set中的成员在集合中的位置是有序的

  常用命令:

      • 添加元素

        • zadd mysort 70 cui 80 li 90 wang(先写分数再写元素,若元素已存在,则替换掉原有分数)
      • 获得元素
        • 获得分数 zscore mysort cui
        • 获得成员数量 zcard mysort
      • 删除元素
        • 删除 zrem mysort li wang
        • 按范围删除 zremrangebyrank mysort 0 4
        • 按分数范围删除 zremrangebyscore mysort 80 100
      • 范围查询
        • 查找全部 zrange mysort 0 -1
        • 查找并显示分数(由小到大) zrange mysort 0 -1 withscores
        • 查找并显示分数(由大到小) zrevrange mysort 0 -1 withscores
      • 扩展命令
        • 返回分数的某个范围的成员的前两个并按从大到小的顺序
          zrangebyscore mysort 0 100 withscores limit 0 2
        • 给li的分数加3 zincrby mysort 3 li
        • 获取分数再某个范围的成员的个数 zount mysort 80 90

  使用场景:

    • 一般用在游戏排名
    • 微博热点话题
    • 构建索引数据

Keys的通用操作

  • keys * 查看所有key
  • del my1 my2 my3 删除指定key
  • exists my1 查看my1是否存在
  • rename my1 my2 重命名为my2
  • expire my1 1000 设置过期时间为1000s
  • ttl my1 查看剩余时间(没有设置返回-1)
  • type my1 查看key的类型
  • flushall 清空数据库

Redis的特性

  • 多数据库
    • 一个Redis最多可提供16个数据库(0-15),也可通过 select 1选择1号数据库
    • 将0数据库的key(myset)到1号数据库 move myset 1
  • Redis事务
    • 通过multi exec discard命令实现事务
      multi 开启事务 直到 exec exec 提交 discard 回滚

Redis的数据结构、通用操作及其特性的更多相关文章

  1. Redis常用数据结构和操作

    1.String 存入字符类型 Set name luowen 设置name = luowen 存储 Get name 获取设置好的name的值 Setnx name luowen 设置name键值为 ...

  2. Redis Keys的通用操作

    keys * 显示所有key 127.0.0.1:6379> keys * 1) "sort1" 2) "l2" 3) "set2" ...

  3. 峰Redis学习(7)Redis 之Keys 通用操作

    keys * 显示所有key   查找所有以s开头的key 用s*  *代表任意字符 127.0.0.1:6379> keys s* 1) "set3" 2) "s ...

  4. Redis<六> Key通用操作

    1). KEYS pattern : 查找所有符合给定模式 pattern 的 key . 如 keys * , keys *list* 2). DEL key [key ...] : 删除给定的一个 ...

  5. Redis学习笔记(3)—— 五种数据类型&keys的通用操作

    一.Redis数据结构介绍 redis是一种高级的key-value的存储系统,其中的key是字符串类型,尽可能满足如下几点: 1)key不要太长,最好不要操作1024个字节,这不仅会消耗内存还会降低 ...

  6. Redis学习--key的通用操作、移库操作、订阅与事务、持久化和总结

    key的通用操作 keys pattern: pattern *表示任意一个多个字符 ?表示任意一个字符 del key1 key2 删除多个key exists keyname 查看是否存在 ren ...

  7. redis的keys常用操作及redis的特性

    redis的keys常用操作 1.获得所有的keys: keys * 2.可以模糊查询 keys:keys  my* 3.删除keys:del mymkey1 mykey2 4.是否存在keys:ex ...

  8. redis入门到精通系列(三):key的通用操作和redis内部db的通用操作

    五种数据类型都用到了key,key本身是一种字符串,通过key可以获取redis中保存的对象.这一篇博客就将介绍key的通用操作. (一)key基本操作 删除key del key key是否存在 e ...

  9. python连接redis、redis字符串操作、hash操作、列表操作、其他通用操作、管道、django中使用redis

    今日内容概要 python连接redis redis字符串操作 redis之hash操作 redis之列表操作 redis其他 通用操作,管道 django中使用redis 内容详细 1.python ...

随机推荐

  1. laravel之路由和控制器与视图

    路由和控制器: : 路由与视图: 访问:

  2. JavaScript基础知识(Math的方法)

    Math的方法 Math : 对象数据类型 : Math: {} 是window下的一个键值对: 属性名叫Math,属性值是一个对象 var obj = {a:1}; console.log(obj. ...

  3. SQL的几种连接:内连接、外连接(左连接、右连接、全连接)

    表结构见前面博客 1.内连接 1.1.等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接表中的所有列,包括其中的重复列. 三种写法: select * from t ...

  4. configure文件的生成

    https://blog.csdn.net/mitesi/article/details/44773951 make 根据Makefile编译源代码,连接,生成目标文件,可执行文件. make cle ...

  5. Mockito单元测试实战

    最近使用Mockito完成了几个简单的测试,写个博客mark一下: 第一种模拟web请求 @SpringBootTest @RunWith(SpringRunner.class) @WebAppCon ...

  6. Java反射机制概念及应用场景

    Java的反射机制相信大家在平时的业务开发过程中应该很少使用到,但是在一些基础框架的搭建上应用非常广泛,今天简单的总结学习一下. 1. 什么是反射机制? Java反射机制是在运行状态中,对于任意一个类 ...

  7. FPC导通阻抗计算

    pc线路板是有导电功能的,那么如何仅适用手工计算出线路的阻值能?那么就需要使用到一个公式: W*R*T=6000 W是指铜箔的宽度单位是密耳mil. T是指铜箔厚度单位是盎司oz. R是指铜箔的电阻单 ...

  8. DAX/PowerBI系列 - 查询参数用法详解(Query Parameter)

    PowerBI  - 查询参数用法详解(Query Parameter) 很多人都不知道查询参数用来干啥,下面总结一下日常项目中常用的几个查询参数的地方.(本人不太欢hardcode的东西) 使用查询 ...

  9. df=df.reset_index(drop=True)

    df=df.reset_index(drop=True) ============ df = pd.read_csv('./train_file/train.csv').dropna()df_test ...

  10. linux发展

    硬件 1946年诞生于宾夕法尼亚州,占地170平米,重量达到30吨,名字叫做ENIAC(electronic numerical integrator and calculator)主要作用是为美国国 ...