zoukankan      html  css  js  c++  java
  • redis的set类型

    1、简单描述

       redis的set类型是string类型数值的无序集合。set元素最大可以包含2的32次方减1个元素。由于set类型是通过hash table实现(旧版本是这样,新版本不确定是不是改用了skip list来实现),所以添加/删除/查找的时间复杂度都是O(1)。hash table有个问题,就是添加或删除的时候,伴随着长度的变化的是需要同步(获取写锁)会阻塞其他读写操作。如果当前版本不是skip list(跳跃表)来实现,那么以后可能也会调整,因为sorted set中已经是使用skip list来实现的。

    2、相关命令(基于4.0.1版本)

    1)sadd命令:往集合里添加元素,支持同时添加多个元素。

    2)scard命令:获取集合中元素的数量。集合不存在则返回0,就是集合里元素个数为0。

     

     3) sismember命令:查看元素是否在集合中,在则返回1,不在集合中或者集合不存在则返回0:

    4)smembers命令:获取集合的所有元素,结果是无序的:

    5)srem命令:删除元素

     

    srem命令支持删除多个操作,返回成功操作的元素的个数:

    6)srandmember命令:随机从集合中获取一个元素,不删除元素。

    7)spop命令:从集合中移除并返回随机数量的元素。

     

     8)smove命令:把元素从一个集合移动到另一个集合。原子操作。

    9)sinter命令:返回给定集合之间的交集,就是共有的元素。

    10)sinterstore命令:把sinter的结果存储到一个集合。

     11)sunion命令:获取指定集合的元素的并集。

     12)sunionstore命令:把sunion操作的结果存储到一个集合。

    【注意】sunionstore命令,把合并的元素存储到一个目标集合中。因为集合的特性,就是集合中不会有重复的元素,那么多次重复sunionstore到同个目标集合也不碍事。

    13)sdiff命令:返回给定的集合的差集,支持多个集合计算差集,返回的结果是存在于第一个集合而不在其他集合上的元素;

    14)sdiffstore命令:类似sdiff命令,只是会把sdiff命令的结果存储到一个集合。

    3、小结

    1)注意sadd的操作结果,如果元素是存在的,那么sadd再次添加会返回0。

    2)注意spop命令和srandmember命令的区别:前者会把元素从集合中移除,后者仅仅是获取随机的元素,不会移除元素。两者的共同点都是能随机获取1个或多个随机的元素。

    3)集合元素数量大的时候,smembers命令会返回很多数据,性能不佳的。如果想判断元素是不是在集合里面用sismember命令,不要用smembers命令获取所有元素然后再去判断。

  • 相关阅读:
    vue中$route和$router的区别
    vscode
    好用的天气插件
    jQuery的slideUp和slideDown函数
    在CSS/JS之后开发工作人员经常会考虑的性能优化。从用户刷新页面,一次js请求下有哪些地方需要缓存
    前端与BI
    XSS和CSRF区别
    兼容性问题
    div跟随鼠标移动
    匀速运动
  • 原文地址:https://www.cnblogs.com/guangye/p/7441481.html
Copyright © 2011-2022 走看看