redis的5种数据结构的简介
5种数据结构
1、字符串
示例
127.0.0.1:6379> set name test
OK
127.0.0.1:6379> get name
"test"
2、列表(有序,字符可以相同)
lpush 将给定值推入列表的左端
rpush 将给定值推入列表的右端
lrange 获取列表在给定范围上的所有制 ps: lrange list-key 0 -1 第二个位置为-1的时候展示所有的内容
lindex 获取列表在给定位置上的单个元素
lpop 从列表左端弹出一个值,并返回被弹出的值
rpop 从列表右端弹出一个值,并返回被弹出的值
127.0.0.1:> lpush list-key item
(integer) 1
127.0.0.1:6379> lrange list-key 0 10
1) "item"
127.0.0.1:6379> lpush list-key item1
(integer) 2
127.0.0.1:6379> lrange list-key 0 10
1) "item1"
2) "item"
127.0.0.1:6379> rpush list-key item2
(integer) 3
127.0.0.1:6379> lrange list-key 0 10
1) "item1"
2) "item"
3) "item2"
127.0.0.1:6379> lindex list-key 1
"item"
127.0.0.1:6379> lpush list-key item (可以存储相同的数据)
(integer) 4
127.0.0.1:6379> lrange list-key 0 -1
1) "item"
2) "item1"
3) "item"
4) "item2"
127.0.0.1:6379> lrange list-key 0 -1
1) "item"
2) "item1"
3) "item"
4) "item2"
删除数据
127.0.0.1:6379> lpop list-key
"item"
127.0.0.1:6379> lrange list-key 0 -1
1) "item1"
2) "item"
3) "item2"
127.0.0.1:6379> rpop list-key
"item2"
127.0.0.1:6379> lrange list-key 0 -1
1) "item1"
2) "item"
3、集合(无序,每个字符不相同)
sadd 将给定元素添加到集合中
smembers 返回集合包含的所有元素
sismember 检查给定元素是否存在于集合中
srem 如果给定的元素存在于集合中,那么移除这个元素
127.0.0.1:> sadd set-key item
(integer)
127.0.0.1:> sadd set-key item1
(integer)
127.0.0.1:> smembers set-key
) "item1"
) "item"
127.0.0.1:> sismember set-key item
(integer)
127.0.0.1:> sismember set-key item2
(integer)
127.0.0.1:> smembers set-key
) "item1"
) "item"
127.0.0.1:> srem set-key item
(integer)
127.0.0.1:> smembers set-key
) "item1"
4、散列(无序,键值不可以重复)
Redis哈希是键值对的集合。 Redis哈希是字符串字段和字符串值之间的映射,所以它们用来表示对象。
hset 在散列里面关联器给定的键值对
hmset 一次可以插入多个值
hget 获取指定散列键的值
hgetall 获取散列包含的多有的键值对
hdel 如果给定键存在于散列里面,那么移除这个键
127.0.0.1:6379> hset hash-key sub-key1 value1
(integer) 1
127.0.0.1:6379> hgetall hash-key
1) "sub-key1"
2) "value1"
127.0.0.1:6379> hset hash-key sub-key2 value2
(integer) 1
127.0.0.1:6379> hgetall hash-key
1) "sub-key1"
2) "value1"
3) "sub-key2"
4) "value2"
127.0.0.1:6379> hget hash-key sub-key1
"value1"
127.0.0.1:6379> hdel hash-key sub-key2
(integer) 1
127.0.0.1:6379> hgetall hash-key
1) "sub-key1"
2) "value1"
127.0.0.1:6379> hmset hash-key sub-key2 value2 sub-key1 value1 sub-key3 value3
OK
127.0.0.1:6379> hgetall hash-key
1) "sub-key1"
2) "value1"
3) "sub-key2"
4) "value2"
5) "sub-key3"
6) "value3"
在上面的例子中,哈希数据类型用于存储包含用户基本信息的用户对象。
5、有序集合
语序集合每个键都有一个浮点数的值,这个值叫分值
zadd 添加到集合中
zrange 获取集合元素
zrangebyscore 获取在给定分值范围内的所有元素
zrem 移除
127.0.0.1:> zadd zset-key memeber1
(integer)
127.0.0.1:> zadd zset-key memeber2
(integer)
127.0.0.1:> zadd zset-key memeber2
(integer)
127.0.0.1:> zrange zset-key -
) "memeber1"
) "memeber2"
127.0.0.1:> zrange zset-key - withscores
) "memeber1"
) ""
) "memeber2"
) "" 127.0.0.1:> zadd zset-key memeber3
(integer)
127.0.0.1:> zrange zset-key - withscores
) "memeber1"
) ""
) "memeber2"
) ""
) "memeber3"
) "" 127.0.0.1:> zrangebyscore zset-key
) "memeber1"
) "memeber2"
) "memeber3"
127.0.0.1:> zrangebyscore zset-key withscores
) "memeber1"
) ""
) "memeber2"
) ""
) "memeber3"
) ""
redis的5种数据结构的简介的更多相关文章
- Redis系列(二):Redis的5种数据结构及其常用命令
上一篇博客,我们讲解了什么是Redis以及在Windows和Linux环境下安装Redis的方法, 没看过的同学可以点击以下链接查看: Redis系列(一):Redis简介及环境安装. 本篇博客我们来 ...
- Redis 中 5 种数据结构的使用场景介绍
这篇文章主要介绍了Redis中5种数据结构的使用场景介绍,本文对Redis中的5种数据类型String.Hash.List.Set.Sorted Set做了讲解,需要的朋友可以参考下 一.redis ...
- Redis入门到高可用(四)—— Redis的五种数据结构的内部编码
Redis的五种数据结构的内部编码
- 详细介绍Redis的几种数据结构以及使用注意事项(转)
原文:详细介绍Redis的几种数据结构以及使用注意事项 1. Overview 1.1 资料 <The Little Redis Book>,最好的入门小册子,可以先于一切文档之前看,免费 ...
- Redis中5种数据结构的使用场景介绍
转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/108.html?1455861435 一.redis 数据结构使用场景 原 ...
- redis中5种数据结构的使用
一.redis 数据结构使用场景 原来看过 redisbook 这本书,对 redis 的基本功能都已经熟悉了,从上周开始看 redis 的源码.目前目标是吃透 redis 的数据结构.我们都知道,在 ...
- Redis 的几种数据结构&五种数据类型对象
先看几种数据结构 通过分析底层的数据结构,学习如何根据场景选型和设计 1,简单动态字符串 redis使用的字符串SDS有别于C语言中的字符串 a, 结构 free字段为已分配但未使用的空间 len为已 ...
- Redis中5种数据结构的使用场景
一.redis 数据结构使用场景 原来看过 redisbook 这本书,对 redis 的基本功能都已经熟悉了,从上周开始看 redis 的源码.目前目标是吃透 redis 的数据结构.我们都知道,在 ...
- Redis的五种数据结构的内部编码
type命令实际返回的就是当前键的数据结构类型,它们分别是:string(字符串).hash(哈希). list(列表).set(集合).zset(有序集合),但这些只是Redis对外的数据结构. 实 ...
随机推荐
- Objective-C中的copy协议
NSObject对象是否可以copy自己 NSObject类没有实现NSCopying或者NSMutableCopying协议,但是却有copy以及mutableCopy实例方法.然而,如果用NSOb ...
- HTML5画布(变形)
坐标变换 案例1: <!DOCTYPE html><html><head lang="en"> <meta charset="U ...
- c# 与 c++ 编译
C#的所有方法封装在类中,类的方法没有先后之分,无需声明.//而C++必须在函数调用前,由编译器检查参数类型是否合法,所以必须知道函数的原形(protype),所以必须提前声明函数的签名(signat ...
- ARM的两种启动方式 (NAND FLASH. NOR FLASH)
为什么会有两种启动方式? 这就是有两种FLASH 的不同特点决定的. NAND FLASH 容量大,存储的单位比特数据的成本要低很多,但是要按照特定的时序对NAND FLASH 进行读写,因此CP ...
- (摘)C#comboBox绑定数据
C#中comboBox用代码绑定数据库中在某一列.用处:跟radioButton联系在一起,可以根据radioButton在选择而在comboBox显示出不同的值. private void radi ...
- 自制单片机之十六……将文字或图形转成LCD上使用的C51字模数据
这一讲说说如何用取模软件将图形转成数据吧,有很多人反复问我这个问题,我就再罗嗦下吧! 取字模的软件有很多款.有的只能将文字转成字模数据,有的既可将文本文字转字模也能将图片转成点阵数据.在这里我就介绍一 ...
- .net 开发必备小抄(电子书)
http://www.syncfusion.com/resources/techportal/ebooks/accountinghttp://www.syncfusion.com/resources/ ...
- URAL 1029
题目大意:M层N列的矩阵(各元素均为正整数),找出一个路径从第一层到达第M层,使得路径上的所有数的和是所有可达路径中最小的,每次上到下一层以后就不能再上去,依次输出路径上的各点在所在层的列数. KB ...
- 深入浅出Node.js (7) - 网络编程
7.1 构建TCP服务 7.1.1 TCP 7.1.2 创建TCP服务器端 7.1.3 TCP服务的事件 7.2 构建UDP服务 7.2.1 创建UDP套接字 7.2.2 创建UDP服务器端 7.2. ...
- @@ROWCOUNT 含义
返回受上一语句影响的行数. 如果行数大于 20 亿,请使用 ROWCOUNT_BIG. Transact-SQL 语句可以通过下列方式设置 @@ROWCOUNT 的值: 将 @@ROWCOUNT 设置 ...