redis-常用数据类型-集合(Set)

 1,简介 

 

  Redis Set提供的功能和List类似,是一个列表的功能,特殊之处在于set是可以自动排重的,

  当你需要储存一个列表数据,又不希望出现重复数据是,set是一个很好的选择,

  并且set提供了判断某个成员是否在set集合内的重要接口,

  Redis的set是string类型的无序集合它底层其实是一个value为null的hash表,所以,添加,删除,查找的复杂度为O(1)

  一个算法,随着数据的增加,执行时间的长短,如果是O(1),数据增加,查找数据的时间不变

 

 2,常用命令 

   sadd   <key>  <value1>  <value2>  <value3> ...  将一个或多个元素添加到集合key中,已存在的元素将被忽略

   smembers   <key>  取出改集合的所有值

   sismember   <key>   <value>  判断集合key中是否有value值,有 1,没有 0

   scard    <key>  返回集合的元素个数

   srem   <key>  <value1>  <value2>  删除集合key中的元素

     spop   <key>  随机从集合中吐出一个值

     srandmember   <key>   <n>  随机从该集合中取出n个值,不会从集合中删除

 

     smove    <source>   <destination>   value  把value从一个集合(source)移动到另一个集合(destination)

     sinter    <key1>  <key2>  两个集合的交集元素

   sunion   <key1>   <key2>  两个集合的并集元素

   sdiff    <key1>  <key2>  返回两个集合的差集(key1中,不在key2中)

 

 3,数据结构

  Set数据结构是dict字典,字典使用hash表实现的

  Java中的HashSet的内部实现是用的 HashMap, 只不过所有的value都指向同一个对象,

  Redis的Set结构也是一样,他的内部也使用hash结构,所有的value都指向同一个内部值。

 

posted @   danny522  阅读(225)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
点击右上角即可分享
微信分享提示