Redis进行键值存储,通常被称为NoSQL数据库。键值存储的本质是存储数据,然后把这个数据和一个关键字映射起来。可以根据关键字来获得被存储的数据。
使用命令SET来存储数据,如果该关键字已经存在,以前的值将被覆盖,无视类型,以前设置的存活时间也将被重置。
可选参数:EX设置以秒为单位的过期时间,PX设置以毫秒为单位的过期时间,NX如果key不存在的话将被存储,XX只有key存在的情况下被存储。
返回值:如果设置成功将返回ok,如果失败返回空。
set将数据“fido”存储在键值“server:name”上:
SET server:name "fido"
获取刚刚存储的数据:
GET server:name
SETNX(set if not exists)命令,它的行为和SET一样,唯一不同就是只有在key不存在的情况下,才会起作用 。
返回值:如果设置成功返回1,否则返回0
删除数据使用DEL命令,DEL key1 key2 ...keyn。如果给定的key不存在,将不进行任何操作。该命令返回值为被删除的条数。
返回值:如果有一个或多个被删除,将返回大于0。如果一个也没删除将返回0。
INCR,DEXR命令对数字数据进行原子增长或减少,INCR key ,INCRBY key integer,DECR key integer,DECRBY key integer。如果key不存在或key对应的数值类型不是数字类型,会把key的值先置为0然后在进行增加或减少(这里有个问题如果数值类型不是数字会报错,和文档说的不一样)。最大值64位有符号integer
返回值:改变后的数值。
SET aNumber 10
INCR aNumber =>11
INCR aNumber =>12
DEL aNumber
GET aNumber =>nil
INCR aNumber =>1
我们明明可以通过如下操作来达到INCR的效果
x = GET aNumber
x = x+1
SET aNumber x
没错,当客户端只有一个时,这么做完全没有问题,如果有两个时会发生什么呢?
客户a端获得aNumber为10
客户b端获得aNumber为10
客户a进行加一操作此时aNumber为11
客户b进行加一操作此时aNumber为11
其实我们希望结果是12,但实际上它是11!因为如上操作不是原子操作,使用INCR命令就可以避免这种问题发生。Redis针对不同的数据类型,提供了许多类似的原子操作命令。
EXPIRE命令设定某个键值对的存活时间,EXPIRE key secondes。过了指定时间将被自动删除。
返回值:设置成功返回1,否则返回0
TTL来查看键值对剩余存活时间,TTL key。
返回值:如果一个key没有时间限制,将返回-1,如果一个key不存在将返回-2。
SET resource:lock "Redis Demo"
EXPIRE resource:lock 120
120秒后resource:lock将被删除。
TTL resource:lock => 113
// after 113s
TTL resource:lock => -2
-2意味该关键字不存在了,-1意味该关键字不会过期。如果对某个键值重复设值他的ttl将被重置。
SET resource:lock "Redis Demo 1"
EXPIRE resource:lock 120
TTL resource:lock => 119
SET resource:lock "Redis Demo 2"
TTL resource:lock => -1