【set:集合类型(高中的集合知识)】

集合类型:无序、不可重复

列表类型:有序、可重复

【set类型】

1.添加元素

语法:sadd key member1 member2......

返回值:返回成功添加的元素个数

2.获取集合中的所有元素

语法:smembers key

3.删除集合中某个元素

4.判断元素是否在集合中

语法:sismember key member

返回值:存在,返回1;不存在,返回0。

【set集合之间的运算】

1.差集A-B

描述:属于集合A,但不属于集合B

语法:sdiff key1 key2...

2.集合的交集A∩B

描述:属于集合A 且属于集合B的元素构成的集合

3.集合的并集A∪B

描述:属于A或属于B的元素构成的集合。

【集合的其他命令】

1.获取集合中的元素个数

语法:scard key

2.从集合中弹出一个元素

由于集合是无序的,所有SPOP命令会从集合中随机弹出一个元素。

【SortedSet类型:zset集合】

sortedSet有叫做zset。

zset是有序集合,可排序的,但是要唯一。

zset和set的不同之处在于,zset是会给set的元素添加一个分数,然后通过这个分数进行排序。

【zset类型】

1.添加元素

描述:向有序集合zset中添加一个元素和该元素的分数,如果该集合已经存在则会使用新的分数替换原有的分数。

返回值:新加入到集合中的元素的个数,不包含之前已经存在的元素。

语法:zadd key score1 member1 score2 member2 score3 member3......

2.获取元素的分数

语法:zscore key member

3.删除元素

描述:删除有序集合中的一个或多个成员,不存在的成员被忽略。

语法:zrem key member1 member2......

4.获得排名在某个范围内的元素列表

描述:按照元素分数从小到大的顺序返回索引从start到stop之间的所有元素(包含两端的元素)

语法:zrange key start stop

描述:按照元素分数从大到小的顺序返回索引从start到stop之间的所有元素(包含两端的元素)

语法:zrevrange key start stop

描述:如果需要获得元素的分数,可以在尾部加上withscores参数

语法:zrange key start stop[withscores]

zrevrange key start stop [withscores]

5.获取元素的排名

描述:从小到达获取某个元素的排名

语法:zrank key member

描述:从大到小获取某个元素的排名

语法:zrevrank key member

6.获取指定分数范围内的元素

语法:zrangebyscore key min max [withscores] [limit offset count]

7.增加某个元素的分数

语法:zincrby key increment member

注意:不可以将increment和member的顺序调换,与之前的不一样

8.获取集合中元素的数量

语法:zcard key

9.获取指定分数范围内的元素个数

语法:zcount key min max

10.按照分数排名范围删除元素

语法:zremrangebyrank key start stop

11.按照分数范围删除元素

语法:zremrangebyscore key min max

【zset应用:商品销售排行榜】

需求:根据商品销售量对商品进行排名显示。

思路:定义商品销售排行榜(sorted set集合),key为items:sellsort,分数为商品的销售量。

写入商品销售量:(编号1001商品,销售量9;编号1002商品,销售量10;编号1003商品,销售量999)

04_Redis数据类型(set、zset)的更多相关文章

  1. Redis数据类型之ZSet(五)

    前言:有序集合zset跟其他类型一样,同样有几种编码方式.主要有两种编码方式,REDIS_ENCODING_ZIPLIST和REDIS_ENCODING_SKIPLIST.ziplist可以表示较小的 ...

  2. NoSQL 之Redis的5大数据类型

    NoSQL 之Redis的5大数据类型 Redis的五大数据类型也称五大数据对象:了解过6大数据结构,Redis并没有直接使用这些结构来实现键值对数据库,而是使用这些结构构建了一个对象系统redisO ...

  3. Redis常用数据类型以及操作

    Redis常用数据类型以及操作 目录 Redis常用数据类型以及操作 一.String数据类型 1. SET/GET/APPEND/STRLEN 2. INCR/DECR/INCRBY/DECRBY ...

  4. Redis数据类型:五大基本数据类型及三种特殊类型

    String (字符串类型) String是redis最基本的类型,你可以理解成Memcached一模一样的类型,一个key对应一个value. String类型是二进制安全的,意思是redis的st ...

  5. python就业班-淘宝-目录.txt

    卷 TOSHIBA EXT 的文件夹 PATH 列表卷序列号为 AE86-8E8DF:.│ python就业班-淘宝-目录.txt│ ├─01 网络编程│ ├─01-基本概念│ │ 01-网络通信概述 ...

  6. 《Redis开发与运维》读书笔记

    一.初始Redis 1.Redis特性与优点 速度快.redis所有数据都存放于内存:是用C语言实现,更加贴近硬件:使用了单线程架构,避免了多线程竞争问题 基于键值对的数据结构,支持的数据结构丰富.它 ...

  7. GEO(地理信息定位)

    核心知识点: 1.GEO是利用zset来存储地理位置信息,可以用来计算地理位置之间的距离,也可以做统计: 2.命令:geoadd geopos geodist geohash georadius/ge ...

  8. Redis和SpringDataRedis

    一.Redis简介 ​ Redis是用C语言开发的一个开源的高性能键值对(key-value)数据库,运行在内存中,由ANSI C编写.企业开发通常采用Redis来实现缓存.同类的产品还有memcac ...

  9. Redis(三)Redis附加功能

    一.慢查询分析 许多存储系统(例如MySql)提供慢查询日志帮助开发和运维人员定位系统存在的慢操作. 所谓慢查询日志就是系统在命令执行前后计算每条命令的执行时间,当超过预设阈值,就将这条命令的相关信息 ...

随机推荐

  1. cmd命令窗口相关操作指南

    cmd命令窗口打开方式:win+R cmd 1.盘符切换 d: 回车 (d为磁盘名) 2.查看当前目录下的文件和文件夹 输入dir 3.进入指定目录(若需跨盘符操作,应先切换盘符) cd(空格)+绝对 ...

  2. [BZOJ 4850][Jsoi2016]灯塔

    传送门 #include <bits/stdc++.h> using namespace std; #define rep(i,a,b) for(int i=a;i<=b;++i) ...

  3. UVA - 10298 后缀数组(仅观赏)

    题意:求最小循环节 \(KMP\)可以20ms通过,而\(da\)实现的后缀数组并无法在3000ms内通过 听说要用\(dc3\)才勉强卡过,这里仅列出\(da\)实现 #include<ios ...

  4. POJ - 3090 gcd水题

    大概题意就是求\(1 \le i,j \le n\)的\(gcd(i,j) = 1\)的个数+2(对于0的特判) 正解应该是欧拉函数或者高逼格的莫比乌斯反演 但数据实在太水直接打表算了 /*H E A ...

  5. Hadoop 使用基础

    [摘录自] https://www.yiibai.com/hadoop/hadoop_hdfs_operations.html#article-start 一.HDFS 使用基础 格式化配置HDFS文 ...

  6. 解决windows10活动历史记录删除问题

    Windows10日常办公过程中系统会记录很多活动历史记录信息,我是不希望我的活动历史记录随时可以被别人查看,虽然电脑有设置密码,但是办公电脑还是习惯将历史记录删除掉,并且永远禁用windows10的 ...

  7. python 爬虫系列01-连接mysql

    爬虫学习中......................................... import pymysql conn = pymysql.connect(host=',database ...

  8. cloudemanager安装时出现8475 MainThread agent ERROR Heartbeating to 192.168.30.1:7182 failed问题解决方法(图文详解)

    不多说,直接上干货!   问题详情 解决这个问题简单的,是因为有进程占用了.比如 # ps aux | grep super root ? Ss : : /opt/cm-/lib64/cmf/agen ...

  9. Column 'orders' in order clause is ambiguous

    今天报了这个错误 原因是.当使用sql查询语句,使用了join查表.但是这个orders没指定是哪张表的字段 ,发生在自关联情况

  10. ife task0003学习笔记(四):JavaScript构造函数

    JavaScript创建对象主要是3种方法:工厂模式.构造函数模式.原型模式.其实对于构造函数的概念,我们并不陌生.在之前学习c++语言的时候,也有提到过构造函数的概念.除了创建对象,构造函数(con ...