前面说过,Redis的一大特性是支持丰富的数据类型,

这为更多的应用场景提供了可能。

Redis有五种数据类型,包括string,list,set,sorted set和hash,
注意,Redis的数据类型不支持嵌套。
下面学习一下这五种数据类型的特点和简单应用。

1.String 字符串

String 数据结构是简单的 key-value 类型,value 不仅可以是 String,也可以是数字(当数字类型用 Long 可以表示的时候encoding 就是整型,其他都存储在 sdshdr 当做字符串)。使用 Strings 类型,可以完全实现目前 Memcached 的功能,并且效率更高。还可以享受 Redis 的定时持久化(可以选择 RDB 模式或者 AOF 模式),操作日志及 Replication 等功能。

应用场景:
应用最广泛,Redis最基础的数据类型。

常用命令:
set,get,将字符串值value关联到key/返回key所关联的字符串值。
incr,将key中储存的数字值增一。
decr,将key中储存的数字值减一。
mset,同时设置一个或多个key-value对。
mget,返回所有(一个或多个)给定key的值。

2.Hash 哈希

很多时候我们需要存储一些对象数据信息,
比如用户信息,包括用户的昵称、年龄、性别等,如果使用String数据类型,
通常是将这些信息序列化后存储为一个JSON 格式的字符串,比如“lilei,18,man”。
如果更新这些信息,需要将字符串(JSON)取出来,进行反序列化,修改某一项的值,再序列化成字符串(JSON)存储回去。在数据的传输和处理时会造成很大的浪费,
这个时候散列数据类型就可以很好解决这个问题。Hash 结构可以直接修改某一项属性值。
实现方式:

常用命令:
HSET 给字段赋值,更新时可以直接覆盖
HGET 获得字段的值
HMSET,HMGET 给多个字段赋值(获得值)
HGETALL 获取键中所有字段和字段值
如,

redis> hmset tom age 18 gender male
OK
redis> hgetall tom
1) "age"
2) "18"
3) "gender"
4) "male"

  

3.List 列表

应用场景:
关注列表,粉丝列表,消息队列等。

实现方式:

list的实现为一个双向链表,即可以支持反向查找和遍历,更方便操作,不过带来了部分额外的内存开销,Redis内部的很多实现,包括发送缓冲队列等也都是用的这个数据结构。

常用命令:
#将一个或多个值value插入到列表key的表头/移除并返回列表key的头元素
lpush,lpop
#将一个或多个值value插入到列表key的表尾(最右边)/移除并返回列表key的尾元素
rpush,rpop
#返回列表 key 中指定区间内的元素,区间以偏移量 start 和 stop 指定
lrange
# LPOP 命令的阻塞版本,当给定列表内没有任何元素可供弹出的时候,连接将被 BLPOP 命令阻塞,直到等待超时或发现可弹出元素为止。
BLPOP(阻塞版)

4.Set 集合

由一个或多个元素所构成的叫做集合。
集合中的元素有三个特征:确定性,互异性,无序性。集合和列表的区别在于列表中的元素有序且并不一定唯一。Redis还为集合提供了求交集、并集、差集等操作。

应用场景:
set对外提供的功能与list类似,但是set可以自动排重,当你需要存储一个列表数据,又不希望出现重复数据时,set是很好的选择。
set提供了判断某个成员是否在一个set集合内的重要接口,这个也是list所不能提供的。

实现方式:
set 的内部实现是一个value为null的HashMap, 实际就是通过计算hash的方式来快速排重的,操作set的时间复杂度始终为O(1)。

常用命令:
#向集合中添加一个或多个元素,返回成功加入的元素
SADD key member1 [member2...]
#删除一个或多个元素
SREM key member [member...]
#随机弹出一个元素
SPOP key
#集合间运算,差集运算
SDIFF key [key...]
#交集运算
SINTER key [key...]
#并集运算
SUNION key [key...]
#获得集合中的所有元素
SMEMBERS key
#判断元素是否在集合中
SISMEMBERS key member

操作实例:

redis>sadd myset a b c
(integer) 3
redis>smembers myset
1) "a"
2) "c"
3) "b"
redis>spop myset
"a"

5.Sorted set 有序集合

有序集合在集合类型的基础上,为每个元素都关联了一个分数,这样除了可以进行集合相关的操作,
还可以根据分数不同,进行排序等操作,有序集合中元素的分数可以是相同的。

应用场景:
以某个条件为权重,比如按顶的次数排序。
可以用Sorted Sets来做带权重的队列,
比如普通消息的score为1,重要消息的score为2,然后工作线程可以选择按score的倒序来获取工作任务。让重要的任务优先执行。

实现方式:
Redis sorted set的内部使用 HashMap 和跳跃表(SkipList)来保证数据的存储和有序,HashMap里放的是成员到score的映射,而跳跃表里存放的是所有的成员,排序依据是HashMap里存的分数。

有序集合和列表的区别:
list和sorted set中元素都是有序的,
列表类型是听过链表实现的,当元素增多时,访问中间元素速度会下降,
而有序集合是用HashMap和跳跃表(SkipList),不存在这个问题,但是有序集合的内存开销比列表要大。

常用命令:
#添加一个或多个成员到有序集合,或者如果它已经存在更新其分数
ZADD key score1 member1 [score2 member2]
#由索引返回一个成员范围的有序集合
ZRANGE key start stop [WITHSCORES]
#移除有序集 key 中的一个或多个成员,不存在的成员将被忽略。
ZREM
#返回有序集 key 的基数。
ZCARD

Redis笔记(三)Redis的数据类型的更多相关文章

  1. redis相关笔记(三.redis设计与实现(笔记))

    redis笔记一 redis笔记二 redis笔记三 1.数据结构 1.1.简单动态字符串: 其属性有int len:长度,int free:空闲长度,char[] bur:字符数组(内容) 获取字符 ...

  2. Redis系列三 Redis数据类型

    一 .Redis的五大数据类型 1.String(字符串) string是redis最基本的数据类型,可以理解成与 Memached一模一样的数据类型,一个key对应一个value. string 类 ...

  3. Redis笔记1-Redis介绍及数据类型使用场景

    Redis介绍:C语言开发.单线程操作.高性能.键值对.可持久化的数据库.Redis采用redisObject结构来统一五种数据类型,redisObject是五种类型的父类,可以在函数间传递时隐藏具体 ...

  4. redis学习笔记(三)——redis的命令大全总结

    总结了一些redis五种存储类型的常用命令以及一些通用操作命令,不是很全,是在学习的时候将学到的做了个汇总,使用的时候可以查一下. 笔记写在表格里面了,不好粘贴.......后面的直接截图了..... ...

  5. redis笔记(三)

     redis配置文件 配置文件对单位大小写不敏感 tcp-backlog  511   高并发环境连接数 tcp-keepalive   单位为秒 0 表示不会进行keepalive检测,,,建议设置 ...

  6. Redis 笔记(一)——数据类型简介

    Redis 是一个 key-value 存储系统,但是它的 value 值不仅仅可以存储字符串,value 共有 五种 数据结构类型,具体如下: 数据结构类型 结构类型 结构存储的值 结构的读写能力 ...

  7. Redis系列(三)-Redis发布订阅及客户端编程

    阅读目录 发布订阅模型 Redis中的发布订阅 客户端编程示例 0.3版本Hredis 发布订阅模型 在应用级其作用是为了减少依赖关系,通常也叫观察者模式.主要是把耦合点单独抽离出来作为第三方,隔离易 ...

  8. redis学习三 redis持久化

      1,快照持久化 1简介      redis可以通过创建快照来获得某个时间点上的内存内容的数据副本,有了副本之后,就可以将副本发送到其他redis服务器上从而创建相同数据的从服务器,同时快照留在原 ...

  9. redis教程(三)-----redis缓存雪崩、缓存穿透、缓存预热

    缓存雪崩 概念 缓存雪崩是由于原有缓存失效(过期),新缓存未到期间.所有请求都去查询数据库,而对数据库CPU和内存造成巨大压力,严重的会造成数据库宕机.从而形成一系列连锁反应,造成整个系统崩溃. 解决 ...

  10. Redis学习笔记(二)Redis支持的5种数据类型的总结之String和Hash

    引言 在Redis学习笔记(一)中我们已经会安装并且简单使用Redis了,接下来我们一起来学习下Redis支持的5大数据类型. 简介 Redis是REmote DIctionary Server(远程 ...

随机推荐

  1. 采用get的方式提交数据到服务器

    1  效果演示:

  2. ExtJS入门教程03,form中怎能没有validation

    接上篇内容,我们在学会extjs form的基本用法之后,今天我们来看看extjs form的validation功能. 必填项,就是不能为空(allowBlank) 效果: 代码: { xtype: ...

  3. xml 嵌入式资源

    使用Ibatis总是说未能加载相应的sqlmap.xml,原来是 xml以内容方式,而不是嵌入式方式载入Dll中

  4. 检测ADO.net拼接字符串中非法字符

    using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Refle ...

  5. 打印多边形的菱形(for的嵌套)

    Console.WriteLine("请输入一个数字,会出现一个多边的菱形:"); int n = Convert.ToInt32(Console.ReadLine()); ; i ...

  6. Jenkins 搭建U3D自动发布 IOS

    http://www.cnblogs.com/yinghuochong/archive/2013/09/01/3294940.html 1.安装包,工具略过. 2.插件管理 Subversion Pl ...

  7. Ueditor配置及在项目中的使用

    引言 上篇中简单介绍了Ueditor的两种定制方式,想了解的请戳这里:Ueditor的两种定制方式.在项目中,Ueditor该怎么使用更方便呢?很容易让人想到将ueditor放入用户控件页,可以拖到需 ...

  8. GPRS GPRS(General Packet Radio Service)是通用分组无线服务技术的简称,它是GSM移动电话用户可用的一种移动数据业务,属于第二代移动通信中的数据传输技术

    GPRS 锁定 本词条由“科普中国”百科科学词条编写与应用工作项目 审核 . GPRS(General Packet Radio Service)是通用分组无线服务技术的简称,它是GSM移动电话用户可 ...

  9. 不起眼却有大作用的 .NET功能集(转发)

    http://www.cnblogs.com/powertoolsteam/p/top15features.html 目录 1. ObsoleteAttribute2. 设置默认值属性: Defaul ...

  10. MVC利用Routing实现多域名绑定一个站点、二级域名以及二级域名注册Area

    最近有这么个需求:在一个站点上绑定多个域名,每个域名进去后都要进入不同的页面.实现了这个功能以后,对于有多个域名,且有虚拟空间,但是虚拟空间却只匹配有一个站点的用户来说,可以节省很多小钱钱. 很久以前 ...