04_Redis数据类型(set、zset)
【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)的更多相关文章
- Redis数据类型之ZSet(五)
前言:有序集合zset跟其他类型一样,同样有几种编码方式.主要有两种编码方式,REDIS_ENCODING_ZIPLIST和REDIS_ENCODING_SKIPLIST.ziplist可以表示较小的 ...
- NoSQL 之Redis的5大数据类型
NoSQL 之Redis的5大数据类型 Redis的五大数据类型也称五大数据对象:了解过6大数据结构,Redis并没有直接使用这些结构来实现键值对数据库,而是使用这些结构构建了一个对象系统redisO ...
- Redis常用数据类型以及操作
Redis常用数据类型以及操作 目录 Redis常用数据类型以及操作 一.String数据类型 1. SET/GET/APPEND/STRLEN 2. INCR/DECR/INCRBY/DECRBY ...
- Redis数据类型:五大基本数据类型及三种特殊类型
String (字符串类型) String是redis最基本的类型,你可以理解成Memcached一模一样的类型,一个key对应一个value. String类型是二进制安全的,意思是redis的st ...
- python就业班-淘宝-目录.txt
卷 TOSHIBA EXT 的文件夹 PATH 列表卷序列号为 AE86-8E8DF:.│ python就业班-淘宝-目录.txt│ ├─01 网络编程│ ├─01-基本概念│ │ 01-网络通信概述 ...
- 《Redis开发与运维》读书笔记
一.初始Redis 1.Redis特性与优点 速度快.redis所有数据都存放于内存:是用C语言实现,更加贴近硬件:使用了单线程架构,避免了多线程竞争问题 基于键值对的数据结构,支持的数据结构丰富.它 ...
- GEO(地理信息定位)
核心知识点: 1.GEO是利用zset来存储地理位置信息,可以用来计算地理位置之间的距离,也可以做统计: 2.命令:geoadd geopos geodist geohash georadius/ge ...
- Redis和SpringDataRedis
一.Redis简介 Redis是用C语言开发的一个开源的高性能键值对(key-value)数据库,运行在内存中,由ANSI C编写.企业开发通常采用Redis来实现缓存.同类的产品还有memcac ...
- Redis(三)Redis附加功能
一.慢查询分析 许多存储系统(例如MySql)提供慢查询日志帮助开发和运维人员定位系统存在的慢操作. 所谓慢查询日志就是系统在命令执行前后计算每条命令的执行时间,当超过预设阈值,就将这条命令的相关信息 ...
随机推荐
- bootstrap的使用2
表单控件: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...
- javascript的代码块
a block of code 注意到这个问题是在看书的时候,中文版中出现“代码片段”这样的词语,于是就去翻看了英文版的原书.书中的用了a block of code,难道不应该翻译成代码块吗?(作为 ...
- [原创]在Centos7上搭建私有的Gitlab服务器
前言 Git作为后起之秀,在版本控制领域占据了头把交椅.Github作为托管式的代码仓库,从代码安全性和网络传输等各个方面考虑,对于个人和公司来讲,具有一定的局限性.Gitlab提供的不同版本的安装包 ...
- 【KMP】洛谷P2375 [NOI2014]动物园 题解
一开始的方向应该对了,但是没有想到合理的优化还是没写出来…… 题目描述 近日,园长发现动物园中好吃懒做的动物越来越多了.例如企鹅,只会卖萌向游客要吃的.为了整治动物园的不良风气,让动物们凭自己 ...
- Python- sort()/sorted()
Python list内置sort()方法用来排序,也可以用python内置的全局sorted()方法来对可迭代的序列排序生成新的序列. sorted(iterable,key=None,revers ...
- wamp下localhost目录Your Projects下项目无法打开解决方案
最近在学PHP,然后可能遇到各种小白问题,记录下来当做自己成长的见证吧: wamp下localhost目录Your Projects下项目无法打开,但是在url中输入项目可以访问到. 解决方案: 注意 ...
- 基于PHPExcel的常用方法总结
// 通常PHPExcel对象有两种实例化的方式// 1. 通过new关键字创建空白文档$phpexcel = newPHPExcel();// 2. 通过读取已有的模板创建$phpexcel =PH ...
- python (1) 还不是大全的小问题
1.pythone 获取系统时间 import datetime nowTime=datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')#现在 pa ...
- ubuntu下安装vue-cli框架
首先安装好node.js,安装方式见 http://www.cnblogs.com/teersky/p/7255334.html 之后正式开始vue-cli之旅吧,输入以下代码安装vue-cli模块 ...
- oracle 错误实例分析(ORA-01126)
问题描述 SQL> shutdown immediate ORA-01109: database not open Database dismounted. ORACLE instance sh ...