Redis 5种主要数据类型和命令

更新日期: 2019-01-08阅读: 2.7k标签: redis

redis是键值对的数据库,有5中主要数据类型

redis常用数据结构:字符串类型(string),散列类型(hash),列表类型(list),集合类型(set),有序集合类型(zset),这是最常用的5中redis数据结构,其实还有些不太常用的数据结构比如:HyperLogLog、GeoHash、PubSub等  


几个基本的命令:

KEYS * 获得当前数据库的所有键

EXISTS key [key ...]  判断键是否存在,返回个数,如果key有一样的也是叠加数

DEL key [key ...]       删除键,返回删除的个数

TYPE key                  获取减值的数据类型(string,hash,list,set,zset)

FLUSHALL                清空所有数据库

CONFIG [get、set]    redis配置

-inf 负无穷

+inf正无穷


一:字符串类型string

字符串类型是Redis的最基本类型,它可以存储任何形式的字符串。其它的四种类型都是字符串类型的不同形式。

最基本的命令:GET、SET         语法:GET key,SET key value   value如果有空格需要双引号以示区分

整数递增:INCR                      语法:INCR key    默认值为0,所以首先执行命令得到 1 ,不是整型提示错误

增加指定的整数:INCRBY          语法:INCRBY key increment

整数递减:DECR                     语法:DECR key   默认值为0,所以首先执行命令得到 -1,不是整型提示错误

减少指定的整数:DECRBY         语法:DECRBY key increment

增加指定浮点数:INCRBYFLOAT 语法:INCRBYFLOAT key increment  与INCR命令类似,只不过可以递增一个双精度浮点数

向尾部追加值:APPEND             语法:APPEND key value   redis客户端并不是输出追加后的字符串,而是输出字符串总长度

获取字符串长度:STRLEN          语法:STRLEN key  如果键不存在返回0,注意如果有中文时,一个中文长度是3,redis是使用UTF-8编码中文的

获取多个键值:MGET                语法:MGET key [key ...]  例如:MGET key1 key2 

设置多个键值:MSET                语法:MSET key value [key value ...]  例如:MSET key1 1 key2 "hello redis"

二进制指定位置值:GETBIT        语法:GETBIT key offset   例如:GETBIT key1 2 ,key1为hello 返回 1,返回的值只有0或1,

                   当key不存在或超出实际长度时为0

设置二进制位置值:SETBIT       语法:SETBIT key offset value ,返回该位置的旧值

二进制是1的个数:BITCOUNT    语法:BITCOUNT key [start end] ,start 、end为开始和结束字节

位运算:BITOP                       语法:BITOP operation destkey key [key ...]  ,operation支持AND、OR、XOR、NOT

偏移:BITPOS                        语法:BITPOS key bit [start] [end]

 

二:散列类型hash

设置单个:HSET                      语法:HSET key field value,不存在时返回1,存在时返回0,没有更新和插入之分

设置多个:HMSET                    语法:HMSET key field value [field value ...]

读取单个:HGET                      语法:HGET key field,不存在是返回nil

读取多个:HMGET                    语法:HMGET key field [field ...]

读取全部:HGETALL                 语法:HGETALL key,返回时字段和字段值的列表

判断字段是否存在:HEXISTS      语法:HEXISTS key field,存在返回1 ,不存在返回0

字段不存在时赋值:HSETNX       语法:HSETNX key field value,与hset命令不同,hsetnx是键不存在时设置值

增加数字:HINCRBY                 语法:HINCRBY key field increment ,返回增加后的数,不是整数时会提示错误

删除字段:HDEL                      语法:HDEL key field [field ...] ,返回被删除字段的个数

只获取字段名:HKEYS               语法:HKEYS key ,返回键的所有字段名

只获取字段值:HVALS              语法:HVALS key  ,返回键的所有字段值

字段数量:HLEN                      语法:HLEN key ,返回字段总数

 

三:列表类型(list)

内部使用双向链表实现,所以获取越接近两端的元素速度越快,但通过索引访问时会比较慢

添加左边元素:LPUSH               语法:LPUSH key value [value ...]  ,返回添加后的列表元素的总个数

添加右边元素:RPUSH              语法:RPUSH key value [value ...]  ,返回添加后的列表元素的总个数

移除左边第一个元素:LPOP        语法:LPOP key  ,返回被移除的元素值

移除右边第一个元素:RPOP        语法:RPOP key ,返回被移除的元素值 

列表元素个数:LLEN                语法:LLEN key, 不存在时返回0,redis是直接读取现成的值,并不是统计个数

获取列表片段:LRANGE           语法:LRANGE key start stop,如果start比stop靠后时返回空列表,0 -1 返回整个列表

                                                    正数时:start 开始索引值,stop结束索引值(索引从0开始)

                                                    负数时:例如 lrange num -2 -1,-2表示最右边第二个,-1表示最右边第一个,

删除指定值:LREM                  语法:LREM key count value,返回被删除的个数

                                                   count>0,从左边开始删除前count个值为value的元素

                                                   count<0,从右边开始删除前|count|个值为value的元素

                                                   count=0,删除所有值为value的元素

索引元素值:LINDEX               语法:LINDEX key index ,返回索引的元素值,-1表示从最右边的第一位

设置元素值:LSET                  语法:LSET key index value

保留列表片段:LTRIM              语法:LTRIM key start stop,start、top 参考lrange命令

一个列表转移另一个列表:RPOPLPUSH      语法:RPOPLPUSH source desctination ,从source列表转移到desctination列表,

                                                                 该命令分两步看,首先source列表RPOP右移除,再desctination列表LPUSH

 

四:集合类型(set)

集合类型值具有唯一性,常用操作是向集合添加、删除、判断某个值是否存在,集合内部是使用值为空的散列表实现的。

添加元素:SADD                    语法:SADD key member [member ...] ,向一个集合添加一个或多个元素,因为集合的唯一性,所以添加相同值时会被忽略。

                        返回成功添加元素的数量。

删除元素:SREM                    语法:SREM key member [member ...] 删除集合中一个或多个元素,返回成功删除的个数。

获取全部元素:SMEMBERS      语法:SMEMBERS key ,返回集合全部元素

值是否存在:SISMEMBER        语法:SISMEMBER key member ,如果存在返回1,不存在返回0

差运算:SDIFF                      语法:SDIFF key [key ...] ,例如:集合A和集合B,差集表示A-B,在A里有的元素B里没有,返回差集合;多个集合(A-B)-C

交运算:SINTER                语法:SINTER key [key ...],返回交集集合,每个集合都有的元素

并运算:SUNION        语法:SUNION key [key ...],返回并集集合,所有集合的元素

集合元素个数:SCARD           语法:SCARD key ,返回集合元素个数

集合运算后存储结果                语法:SDIFFSTROE destination key [key ...] ,差运算并存储到destination新集合中

                   SINTERSTROE destination key [key ...],交运算并存储到destination新集合中

                                                  SUNIONSTROE destination key [key ...],并运算并存储到destination新集合中

随机获取元素:SRANDMEMGER 语法:SRANDMEMBER key [count],根据count不同有不同结果,count大于元素总数时返回全部元素

                  count>0 ,返回集合中count不重复的元素

                  count<0,返回集合中count的绝对值个元素,但元素可能会重复

弹出元素:SPOP                     语法:SPOP key [count] ,因为集合是无序的,所以spop会随机弹出一个元素

 

五:有序集合类型

添加集合元素:ZADD              语法:ZADD key [NX|XX] [CH] [INCR] score member [score member ...],不存在添加,存在更新。

获取元素分数:ZSCORE          语法:ZSCORE key member ,返回元素成员的score 分数

元素小到大:ZRANGE             语法:ZRANGE key start top [WITHSCORES] ,参考LRANGE ,加上withscores 返回带元素,即元素,分数

                                                  当分数一样时,按元素排序

元素大到小:ZREVRANGE       语法:ZREVRANGE key start [WITHSCORES] ,与zrange区别在于zrevrange是从大到小排序

指定分数范围元素:ZRANGEBYSCORE   语法:ZRANGEBYSCORE key min max [WITHSCORE] [LIMIT offest count]

                返回从小到大的在min和max之间的元素,( 符号表示不包含,例如:80-100,(80 100,

                  withscore返回带分数

                  limit offest count 向左偏移offest个元素,并获取前count个元素

指定分数范围元素:ZREVRANGESCORE   语法:ZREVRANGEBYSCORE key max  min [WITHSCORE] [LIMIT offest count]

                与zrangebyscore类似,只不过该命令是从大到小排序的。

增加分数:ZINCRBY                语法:ZINCRBY key increment member ,注意是增加分数,返回增加后的分数;如果成员不存在,则添加一个为0的成员。


链接: https://www.fly63.com/article/detial/1799

在使用redis-cluster之前你需要知道这些事

前段时间基础架构组、DBA还有云盘团队一起推广了phpredis的RedisCluster的线上使用,目前线上业务已经稳定,单业务的规模水平是:Qps平均15W,数据量在700G左右。现对这段时间的工作和所遇到的一些常见问题进行简单总结

Redis可视化管理工具有哪些?

redis 是当前非常流行的缓存数据库,得益于其简单的 key-value 模式的数据存储和丰富的数据类型与事件机制使得 redis 成为当前后端开发中不可或缺的利器。下面推荐一些好用的 redis 的管理工具

Redis 中 Lua 脚本的应用和实践

前段时间组内有个投票的产品,上线前考虑欠缺,导致被刷票严重。后来,通过研究,发现可以通过 redis lua 脚本实现限流,这里将 redis lua 脚本相关的知识分享出来,讲的不到位的地方还望斧正。

Redis在Php项目中的实际应用场景

Redis在Php项目中的实际应用场景:商品维度计数、用户维度计数、存储社交关系、用作缓存代替memcached、反spam系统、用户Timeline/Feeds、最新列表&排行榜、消息通知、将Redis用作消息队列

PHP使用redis防止大并发下二次写入

php调用redis进去读写操作,大并发下会出现:读取key1,没有内容则写入内容,但是大并发下会出现同时多个php进程写入的情况,这个时候需要加一个锁,即获取锁的php进程有权限写。

Redis的主从复制

Redis配置成主从模式,主库(Master)只负责写数据,从库(Slave)只负责读数据。一个主库可以拥有多个从库,但一个从库只能隶属于一个主库。

Redis常用命令

连接操作命令,持久化,远程服务控制,对value操作的命令,String,List,Set,Hash,Redis 发布订阅命令,Redis 事务命令,查看keys个数,清空数据库

分布式锁的redis缓存使用方式

目前有很多成熟的缓存产品,包括Redis,memcached等。这里以Redis为例来分析下使用缓存实现分布式锁的方案。主要的实现方式是使用Jedis.setNX方法来实现。以上实现方式同样存在几个问题:

Redis的正确使用姿势

说到分布式缓存,可能大多数人脑海浮现的就是redis了,为什么redis能够在竞争激烈的缓存大战中脱颖而出呢?原因无非有一下几点:性能好,丰富的特性跟数据结构,api操作简单。但是用的人多了,就会出现很多不规范或者疏忽的地方,严重的时候甚至会导致生产事故

redis用在哪里?redis 应用场景

Redis是一个由Salvatore Sanfilippo写的key-value存储系统。Redis是一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!