Redis详解:strings数据类型及操作

Redis的作者antirez(Salvatore Sanfilippo)曾经发表了一篇名为Redis宣言(Redis Manifesto)的文章,文中列举了Redis 的七个原则,以向大家阐明Redis 的思想。

  1、Redis是一个操作数据结构的语言工具,它提供基于TCP的协议以操作丰富的数据结构。在Redis中,数据结构这个词的意义不仅表示在某种数据结构上的操作,更包括了结构本身及这些操作的时间空间复杂度。

  2、Redis定位于一个内存数据库,正是由于内存的快速访问特性,才使得Redis能够有如此高的性能,才使得Redis能够轻松处理大量复杂的数据结构,Redis会尝试其它的存储方面的选择,但是永远不会改变它是一个内存数据库的角色。

  3、Redis使用基础的API操作基础的数据结构,Redis的API与数据结构一样,都是一些最基础的元素,你几乎可以将任何信息交互使用此API格式表示。作者调侃说,如果有其它非人类的智能生物存在,他们也能理解Redis的API。因为它是如此的基础。

  4、Redis有着诗一般优美的代码,经常有一些不太了解Redis 有的人会建议Redis采用一些其它人的代码,以实现一些Redis 未实现的功能,但这对我们来说就像是非要给《红楼梦》接上后四十回一样。

  5、Redis始终避免复杂化,我们认为设计一个系统的本质,就是与复杂化作战。我们不会为了一个小功能而往源码里添加上千行代码,解决复杂问题的方法就是让复杂问题永远不要提复杂的问题。

  6、Redis支持两个层成的API,第一个层面包含部分操作API,但它支持用于分布式环境下的Redis。第二个层面的API支持更复杂的multi-key操作。它们各有所长,但是我们不会推出两者都支持的API,但我们希望能够提供实例间数据迁移的命令,并执行multi-key操作。

  7、我们以优化代码为乐,我们相信编码是一件辛苦的工作,唯一对得起这辛苦的就是去享受它。如果我们在编码中失去了乐趣,那最好的解决办法就是停下来。我们决不会选择让Redis不好玩的开发模式。

  Redis的作者antirez曾笑称Redis为一个数据结构服务器(data structures server),我认为这是一个非常准确的表述,Redis的所有功能就是将数据以其固有的几种结构来保存,并提供给用户操作这几种结构的接口。本文将介绍Redis支持的各种数据类型及其操作接口。

strings类型及操作

  string是最简单的类型,你可以理解成与Memcached是一模一样的类型,一个key对应一个value,其上支持的操作与Memcached的操作类似。但它的功能更丰富。

  string类型是二进制安全的。意思是redis的string可以包含任何数据,比如jpg图片或者序列化的对象。从内部实现来看其实string可以看作byte数组,最大上限是1G字节,下面是string类型的定义:

  struct sdshdr {
  long len;
  long free;
  char buf[];
  };

  len是buf数组的长度。

  free是数组中剩余可用字节数,由此可以理解为什么string类型是二进制安全的了,因为它本质上就是个byte数组,当然可以包含任何数据了

  buf是个char数组用于存贮实际的字符串内容,其实char和c#中的byte是等价的,都是一个字节。

  另外string类型可以被部分命令按int处理.比如incr等命令,如果只用string类型,redis就可以被看作加上持久化特性的memcached。当然redis对string类型的操作比memcached还是多很多的,具体操作方法如下:

  1、set

  设置key对应的值为string类型的value。

  例如我们添加一个name= HongWan的键值对,可以这样做:

  redis 127.0.0.1:6379> set name HongWan
  OK
  redis 127.0.0.1:6379>

  2、setnx

  设置key对应的值为string类型的value。如果key已经存在,返回0,nx是not exist的意思。

  例如我们添加一个name= HongWan_new的键值对,可以这样做:

  redis 127.0.0.1:6379> get name
  "HongWan"
  redis 127.0.0.1:6379> setnx name HongWan_new
  (integer) 0
  redis 127.0.0.1:6379> get name
  "HongWan"
  redis 127.0.0.1:6379>

  由于原来name有一个对应的值,所以本次的修改不生效,且返回码是0。

  3、setex

  设置key对应的值为string类型的value,并指定此键值对应的有效期。

  例如我们添加一个haircolor= red的键值对,并指定它的有效期是10秒,可以这样做:

  redis 127.0.0.1:6379> setex haircolor 10 red
  OK
  redis 127.0.0.1:6379> get haircolor
  "red"
  redis 127.0.0.1:6379> get haircolor
  (nil)
  redis 127.0.0.1:6379>

  可见由于最后一次的调用是10秒以后了,所以取不到haicolor这个键对应的值。

  4、setrange

  设置指定key的value值的子字符串。

  例如我们希望将HongWan的126邮箱替换为gmail邮箱,那么我们可以这样做:

  redis 127.0.0.1:6379> get name
  "[email protected]"
  redis 127.0.0.1:6379> setrange name 8 gmail.com
  (integer) 17
  redis 127.0.0.1:6379> get name
  "[email protected]"
  redis 127.0.0.1:6379>

  其中的8是指从下标为8(包含8)的字符开始替换

5、mset

  一次设置多个key的值,成功返回ok表示所有的值都设置了,失败返回0表示没有任何值被设置。

  redis 127.0.0.1:6379> mset key1 HongWan1 key2 HongWan2
  OK
  redis 127.0.0.1:6379> get key1
  "HongWan1"
  redis 127.0.0.1:6379> get key2
  "HongWan2"
  redis 127.0.0.1:6379>

  6、msetnx

  一次设置多个key的值,成功返回ok表示所有的值都设置了,失败返回0表示没有任何值被设置,但是不会覆盖已经存在的key。

  redis 127.0.0.1:6379> get key1
  "HongWan1"
  redis 127.0.0.1:6379> get key2
  "HongWan2"
  redis 127.0.0.1:6379> msetnx key2 HongWan2_new key3 HongWan3
  (integer) 0
  redis 127.0.0.1:6379> get key2
  "HongWan2"
  redis 127.0.0.1:6379> get key3
  (nil)

  可以看出如果这条命令返回0,那么里面操作都会回滚,都不会被执行。

  7、get

  获取key对应的string值,如果key不存在返回nil。

  例如我们获取一个库中存在的键name,可以很快得到它对应的value

  redis 127.0.0.1:6379> get name
  "HongWan"
  redis 127.0.0.1:6379>

  我们获取一个库中不存在的键name1,那么它会返回一个nil以表时无此键值对

  redis 127.0.0.1:6379> get name1
  (nil)
  redis 127.0.0.1:6379>

  8、getset

  设置key的值,并返回key的旧值。

  redis 127.0.0.1:6379> get name
  "HongWan"
  redis 127.0.0.1:6379> getset name HongWan_new
  "HongWan"
  redis 127.0.0.1:6379> get name
  "HongWan_new"
  redis 127.0.0.1:6379>

  接下来我们看一下如果key不存的时候会什么样儿?

  redis 127.0.0.1:6379> getset name1 aaa
  (nil)
  redis 127.0.0.1:6379>

  可见,如果key不存在,那么将返回nil

 9、getrange

  获取指定key的value值的子字符串。

  具体样例如下:

  redis 127.0.0.1:6379> get name
  "[email protected]"
  redis 127.0.0.1:6379> getrange name 0 6
  "HongWan"
  redis 127.0.0.1:6379>

  字符串左面下标是从0开始的

  redis 127.0.0.1:6379> getrange name -7 -1
  "126.com"
  redis 127.0.0.1:6379>

  字符串右面下标是从-1开始的

  redis 127.0.0.1:6379> getrange name 7 100
  "@126.com"
  redis 127.0.0.1:6379>

  当下标超出字符串长度时,将默认为是同方向的最大下标

  10、mget

  一次获取多个key的值,如果对应key不存在,则对应返回nil。

  具体样例如下:

  redis 127.0.0.1:6379> mget key1 key2 key3
  1) "HongWan1"
  2) "HongWan2"
  3) (nil)
  redis 127.0.0.1:6379>

  key3由于没有这个键定义,所以返回nil。

  11、incr

  对key的值做加加操作,并返回新的值。注意incr一个不是int的value会返回错误,incr一个不存在的key,则设置key为1

  redis 127.0.0.1:6379> set age 20
  OK
  redis 127.0.0.1:6379> incr age
  (integer) 21
  redis 127.0.0.1:6379> get age
  "21"
  redis 127.0.0.1:6379>

  12、incrby

  同incr类似,加指定值 ,key不存在时候会设置key,并认为原来的value是 0

  redis 127.0.0.1:6379> get age
  "21"
  redis 127.0.0.1:6379> incrby age 5
  (integer) 26
  redis 127.0.0.1:6379> get name
  "[email protected]"
  redis 127.0.0.1:6379> get age
  "26"
  redis 127.0.0.1:6379>

 13、decr

  对key的值做的是减减操作,decr一个不存在key,则设置key为-1

  redis 127.0.0.1:6379> get age
  "26"
  redis 127.0.0.1:6379> decr age
  (integer) 25
  redis 127.0.0.1:6379> get age
  "25"
  redis 127.0.0.1:6379>

  14、decrby

  同decr,减指定值。

  redis 127.0.0.1:6379> get age
  "25"
  redis 127.0.0.1:6379> decrby age 5
  (integer) 20
  redis 127.0.0.1:6379> get age
  "20"
  redis 127.0.0.1:6379>

  decrby完全是为了可读性,我们完全可以通过incrby一个负值来实现同样效果,反之一样。

  redis 127.0.0.1:6379> get age
  "20"
  redis 127.0.0.1:6379> incrby age -5
  (integer) 15
  redis 127.0.0.1:6379> get age
  "15"
  redis 127.0.0.1:6379>

  15、append

  给指定key的字符串值追加value,返回新字符串值的长度。

  例如我们向name的值追加一个@126.com字符串,那么可以这样做:

  redis 127.0.0.1:6379> append name @126.com
  (integer) 15
  redis 127.0.0.1:6379> get name
  "[email protected]"
  redis 127.0.0.1:6379>

  16、strlen

  取指定key的value值的长度。

  redis 127.0.0.1:6379> get name
  "HongWan_new"
  redis 127.0.0.1:6379> strlen name
  (integer) 11
  redis 127.0.0.1:6379> get age
  "15"
  redis 127.0.0.1:6379> strlen age
  (integer) 2
  redis 127.0.0.1:6379>

时间: 2024-10-08 00:35:04

Redis详解:strings数据类型及操作的相关文章

Redis详解:sorted sets数据类型及操作

sorted set是set的一个升级版本,它在set的基础上增加了一个顺序属性,这一属性在添加修改元素的时候可以指定,每次指定后,zset会自动重新按新的值调整顺序.可以理解为有两列的mysql表,一列存value,一列存顺序.操作中key理解为zset的名字. 系列文章: Redis详解:strings数据类型及操作 Redis详解:hashes数据类型及操作 Redis详解:lists数据类型及操作 Redis详解:sets数据类型及操作 和set一样sorted set也是string类

Redis详解:sets数据类型及操作

set是集合,和我们数学中的集合概念相似,对集合的操作有添加删除元素,有对多个集合求交并差等操作,操作中key理解为集合的名字. 系列文章: Redis详解:strings数据类型及操作 Redis详解:hashes数据类型及操作 Redis详解:lists数据类型及操作 Redis的set是string类型的无序集合.set元素最大可以包含(2的32次方)个元素. set的是通过hash table实现的,所以添加.删除和查找的复杂度都是O(1).hash table会随着添加或者删除自动的调

Spring Data操作Redis详解

Spring Data操作Redis详解 Redis是一种NOSQL数据库,Key-Value形式对数据进行存储,其中数据可以以内存形式存在,也可以持久化到文件系统.Spring data对Redis进行了很好的封装,用起来也是十分的得心应手.Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 它支持多种类型的数据结构,如 字符串(strings), 散列(hashes), 列表(lists), 集合(sets), 有序集合(sorted se

使用Python操作Redis详解

之前的五天,过了个愉快的周末,然后将公司AbaseDump的调度部分代码看懂并且在此之上完成了OnlyDump的功能代码,代码不可以公开,今天完工,明天测试,晚上来总结一下这几天学到的一点应用. 使用Python操作Redis详解 ------------------------------------------------------------------------------------------------- 一. 文档说明 本文档仅介绍Redis在Python中的使用,Redis

基础拾遗------redis详解

基础拾遗 基础拾遗------redis详解 基础拾遗------反射详解 基础拾遗------委托详解 基础拾遗------接口详解 基础拾遗------泛型详解 前言 这篇文章和以往的基础拾遗有所不同,以前的介绍的都是c#基础,今天介绍的是redis.因为项目中一只在使用,我想现在大部分项目中都会用到nosql,缓存,今天就介绍一下redis..废话少说下面开始正题. 1.redis是什么? Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. 对的redi

.Net使用Redis详解之ServiceStack.Redis(七)

原文:.Net使用Redis详解之ServiceStack.Redis(七) 序言 本篇从.Net如何接入Reis开始,直至.Net对Redis的各种操作,为了方便学习与做为文档的查看,我做一遍注释展现,其中会对list的阻塞功能和事务的运用做二个案例,进行记录学习. Redis官方推荐的.NET驱动类库为Service.Stack.Redis.然而网上对这个类库的中文文档不是很全面与合理,这篇文章主要就对这个类库做注释展现.不足遗漏之处还望见谅,海涵. .Net使用Redis是非常方便与快捷与

Redis详解(一)——RDB

Redis详解(一)--RDB 前言 由于 Redis 是一个内存数据库,所谓内存数据库,就是将数据库中的内容保存在内存中,这与传统的MySQL,Oracle等关系型数据库直接将内容保存到硬盘中相比,内存数据库的读写效率比传统数据库要快的多(内存的读写效率远远大于硬盘的读写效率).但是保存在内存中也随之带来了一个缺点,一旦断电或者宕机,那么内存数据库中的数据将会全部丢失. 为了解决这个缺点,Redis提供了将内存数据持久化到硬盘,以及用持久化文件来恢复数据库数据的功能.Redis 支持两种形式的

Redis详解(二)——AOF

Redis详解(二)--AOF 前言 RDB 持久化存在一个缺点是一定时间内做一次备份,如果redis意外down掉的话,就会丢失最后一次快照后的所有修改(数据有丢失).对于数据完整性要求很严格的需求,怎么解决呢? 本篇博客接着来介绍Redis的另一种持久化方式--AOF. 1.AOF简介 Redis的持久化方式之一RDB是通过保存数据库中的键值对来记录数据库的状态.而另一种持久化方式 AOF 则是通过保存Redis服务器所执行的写命令来记录数据库状态. 比如对于如下命令: RDB 持久化方式就

Redis详解(八)——企业级解决方案

Redis详解(八)--企业级解决方案 缓存预热 缓存预热就是系统上线后,提前将相关的缓存数据直接加载到缓存系统.避免在用户请求的时候,先查询数据库,然后再将数据缓存的问题!用户直接查询事先被预热的缓存数据! 缓存预热解决方案: 缓存雪崩 缓存雪崩就是在一个较短的时间内,缓存中较多的key集中过期 假设我们的缓存是在同一时间创建(如天猫双十一),然后设置的缓存时间是一置的, 这样到特定的时间就会出现缓存雪崩的情况, 此时若是有大量访问量的操作就会造成数据库服务器的压力过大. 缓存雪崩解决方案: