集合Set 

 
Redis 的集合不是 个线性结构,而是一个哈希表结构,它的内部会根据 hash 分子来
存储和查找数据,理论上 个集合可以存储 232 (大约 42 亿)个元素,因为采用哈希表结
构,所以对于 Redis 集合的插入、删除和查找的复杂度都是 0(1 ),只是我们需要注意:
 
1.对于集合而言,它的每 个元素都是不能重复的,当插入相同记录的时候都会失败
2.集合是无序的。
3.集合的每 个元素都是 String 数据结构类型。
 
Red is 的集合可以对于不同的集合进行操作,比如求出两个或者以上集合的交集、 差集和并集等。

sadd/smembers/sismember

sadd key number [member2 .....]  给键为key的集合增加成员,可增加多个
smembers key  返回集合所有成员
sismember  key member  判断member是否是key集合的成员

 scard,获取集合里面的元素个数
    获取集合里面的元素个数
scard key

srem key value 删除集合中元素
srem key member [ member2 .... ]
移除集合中 元素,可以是多个元素

 srandmember key 某个整数(随机出几个数)
 *   从set集合里面随机取出2个
 *   如果超过最大数量就全部取出,
 *   如果写的值是负数,比如-3 ,表示需要取出3个,但是可能会有重复值。
srandmember key [count]
count为随机出数的个数,默认为1,为负数则取绝对值

spop key 随机出栈
随机弹 集合的一个元素
注意其随机性 因为集合是无序的

smove key1 key2 在key1里某个值      作用是将key1里的某个值赋给key2
smove src des member
将成员 member 从集合 src 迁移到集合 des
原来集合的值可以说已经没有了,直接去了另一个集合,另一个集合可以存在,不存在则创建

差集:sdiff
交集:sinter
并集:sunion
 
sdiff key I [key2]   找出两个综合的差集                参数如果是单 key ,那么 Red is 就返回这key 的所有元素
sinter key I [key2]  key key2 两个集合的交集。    参数如果是单 key ,那么 Red is 就返回这key 的所有元素
sunion key l [key2]     求两 集合 并集                   参数如果是单 key ,那么 Red is 就返回这key 的所有元素

Hash哈希
Redis 中哈希结构就如同 Java map 一样 个对象里面有许多键值对,它是特别
合存储对象的 ,如果内存足够大,那么 Redis hash 结构可以存储 232_ 键值对 40
多亿)。 般而言 不会使用到那么大的一个键值对,所以我们认为 Redis 可以存储很多的
键值对。在 Redis 中, hash 是一个 String 类型的 field value 映射表,因此我们存储的
数据实际在 Redis内存中的一个字符串
 
hash 的键值对在内存中是一种无序的状态

KV模式不变,但V是一个键值对
 

hset/hget/hmset/hmget/hgetall/hdel
hset key file value:设置键值对  单个
hget :获取属性值  单个
 

hmset key field1 value1 [filed2 value2...]  设置键值对, 多个
hmget:获取多个hash指定键的值   多个
 

hgetall:获取所有hash结构中的值

 

hdel:删除hash中的某些字段

 

hlen返回key中的数量

 

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

 

hkeys/hvals
hkeys:获取所有的键
hvals:获取所有的值
 

hincrby/hincrbyfloat
hincrby key field incremen:指定给 hash 结构中的某 字段加上 个整,要求该字段也是整数字符串
hincrbyfloat key field increment:指定给 hash 结构中的某 字段加上 个浮点数,要求该字段也是整数字符串
 

 hsetnx:不存在赋值,存在了无效。
hsetnx key field value
 

 

有序集合:
只是说它是有序的
和无序集合的主要区别在于每 个元素除了值之外,它还会多一个分数
分数是一个浮点数,在 Java 中是使用双精度表示的
 
Redis 就可以支持对分数从小到大或者从大到小的排序。这里和无序集合一样,对于
每一个元素都是唯一的 ,但是对于不同元素而 ,它的分数可以一样。

有序集合是依赖 key 标示它是属于哪个集合,依赖分数进行排序,所以值和分数是必须的

 zadd/zrange
zadd key score value(value1) 【score2 value2 ...] :增加一个或多个成员,key不存在则创建有序集合

zrangebyscore key 开始score 结束score

zrem key 某score下对应的value值,作用是删除元素
 
zcard/zcount key score区间/zrank key values值,作用是获得下标值/zscore key 对应值,获得分数
zcard:统计个数
zcount key score: zcount key min max        根据分数返回对应的成员列表
zrank key values:

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

 zrevrange  从大到小的按分数排序
zrevrange key start end

zrevrangebyscore  key 结束score 开始score
从大到小的按分数排序
zrevrangebyscore key max min [withscores

Redis数据类型(下)的更多相关文章

  1. redis数据类型及使用场景

    Redis数据类型  String: Strings 数据结构是简单的key-value类型,value其实不仅是String,也可以是数字. 常用命令:  set,get,decr,incr,mge ...

  2. Redis-cluster集群【第一篇】:redis安装及redis数据类型

    Redis介绍: 一.介绍 redis 是一个开源的.使用C语言编写的.支持网络交互的.可以基于内存也可以持久化的Key-Value数据库. redis的源码非常简单,只要有时间看看谭浩强的C语言,在 ...

  3. redis笔记总结之redis数据类型及常用命令

    三.常用命令 3.1 字符串类型(string) 字符串类型是Redis中最基本的数据类型,一个字符串类型的键允许存储的数据的最大容量为512MB. 3.1.1 赋值与取值: SET key valu ...

  4. redis介绍、安装、redis持久化、redis数据类型

    1.redis介绍  2.安装管网:https://redis.io/下载:wget -c http://download.redis.io/releases/redis-4.0.11.tar.gz解 ...

  5. Redis(三):Redis数据类型

    Redis数据类型目录导航: Redis五大数据类型 哪里去获取Redis常见数据类型操作命令 Redis键(Key) Redis字符串(String) Redis列表(List) Redis集合(S ...

  6. Redis数据类型和操作

    <"Java技术员"成长手册>,包含框架.存储.搜索.优化.分布式等必备知识,都收集在GitHub JavaEgg ,N线互联网开发必备技能兵器谱,欢迎指导 Redis ...

  7. redis数据类型及订阅操作

    Redis数据类型详解 Redis键/值介绍 Redis key值是二进制安全的,这意味着可以用任何二进制序列作为key值,从形如“foo”的简单字符串到一个JPG文件的内容都可以.空字符串也是有效k ...

  8. Redis数据类型Strings、Lists常用操作指令

    Redis数据类型Strings.Lists常用操作指令 Strings常用操作指令 GET.SET相关操作 # GET 获取键值对 127.0.0.1:6379> get name (nil) ...

  9. Redis数据类型:Hashes、Geo操作指令

    Redis数据类型:Hashes.Geo操作指令 Hashes常用操作指令 Redis Hashes是一个键值对的映射表,最对能存储2^32-1(约40亿)个键值对. HSET HGET HSET:将 ...

  10. redis深入学习(一)-----CAP、redis数据类型

    NoSQL数据库的四大分类 KV键值: memcache+redis 文档型数据库(bson格式比较多): MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在 ...

随机推荐

  1. C# 多线程系列之Mutex使用

    互斥量是一个内核对象,它用来确保一个线程独占一个资源的访问,并且互斥量可以用于不同进程中的线程互斥访问资源. 我们可以把Mutex看作一个出租车,乘客看作线程.乘客首先等车,然后上车,最后下车.当一个 ...

  2. rabbit工作队列模式

    工作队列比简单队列在消费者这边多了一个方法. channel.basicQos(1);公平队列消费(参数设置为1,表示消费者消费完一条才会去接受再次发来的消息) 生产者: package com.kf ...

  3. Selector#wakeup()

    看thrift源码发现selector.wakeup()方法,通常在selector.select()后线程会阻塞.使用wakeup()方法,线程会立即返回.源码分析应该是用的线程中断实现的.下面是个 ...

  4. ZT 为什么Java中继承多数是有害的?

    大多数好的设计者象躲避瘟疫一样来避免使用实现继承(extends 关系).实际上80%的代码应该完全用interfaces写,而不是通过extends.“Java设计模式”一书详细阐述了怎样用接口继承 ...

  5. svn怎么下载代码到本地

    1. 在我们安装好svn时,在指定的目录中点击鼠标右键SVN Checkout,弹出以下窗口.(在文件夹下各自建好前后台的文件夹分别check) 2. 在URL of repository:(存储库的 ...

  6. 第5章 css与背景相关的样式background

    background-origin 设置元素背景图片的原始起始位置. 语法: background-origin : border-box | padding-box | content-box; 参 ...

  7. java 单例的实现及多线程下的安全

    package com.demo01; public class Single { /** * 设计模式:单例设计模式 * 解决一个类中只允许存在一个对象这种情况: * 不允许通过类,无限制的创建该类 ...

  8. visual studio 2013的C++开发环境不错--vs2013安装试用手记

    原文:http://blog.csdn.net/haoyujie/article/details/24370189 从visual studio 体系,最后一次对C++实现了大的改进,那还是vs 7. ...

  9. java面试题之----Java内部类

    这是我学习Java内部类的笔记 1.为什么使用内部类? 使用内部类最吸引人的原因是:每个内部类都能独立地继承一个(接口的)实现,所以无论外围类是否已经继承了某个(接口的)实现, 对于内部类都没有影响 ...

  10. layui分页

    毕业已经两年,期间经历了很多.一个人欢笑与哭泣,在墙角.在路边.在床上.每天搭乘首班车来到公司,每天无数次反省自己,每天每天再问自己为什么活着. 一.下载并引用css和js 地址:点我 <lin ...