传统数据库,如果想实现一个计数,比如记录一篇文章的访问次数,当有新的访问到来时,先要去数据库中查询这篇文章的访问量,然后加1,最后重新写入数据库,在这个过程中,如果
传统数据库,如果想实现一个计数,比如记录一篇文章的访问次数,当有新的访问到来时,先要去数据库中查询这篇文章的访问量,然后加1,最后重新写入数据库,在这个过程中,如果有并发就可能导致计数错误,所以,更新文章访问量的代码都是需要加锁的,以防止同时修改。
Redis的所有操作都是原子性的,也就是说,不论多少个客户端在对一个key进行操作,你不必担心并发导致的类似错误,因为Redis在实现上已经对这类问题进行处理。
一个key,如果所存储的value是数值类型,那么就可以对其进行incr操作
这里为了方便,一直在说incr操作,其实,对于不同的数值,是要采用不同的操作方式的
如果是整数,那么可以对其进行incr操作,incrby 操作和incrbyfloat操作,这些操作都可以,但是对于float类型的数值,就只能进行incrbyfloat的操作,而且对一个整数进行了incrbyfloat操作后,这个数值就编程了float类型的了,就无法再对其进行incr和incrby的操作
对应的增加操作,也有减少操作,分别为decr 和 decrby inrc和decr默认增加1和减少1,奇怪的是,有incrbyfloat的操作,却没有与之对应的decrbyfloat操作,至少我目前还没有找到,那么如果想要减少该怎么办呢,很简单,使用负数就可以了
如果我们对一个key进行操作,但是这个key又不存在,那么redis会自己建立这个key然后在按照命令进行操作。关于这一点,我无法保证适用于所有的命令。
# coding=utf-8'''Created on 2015-9-8@author: kwsy'''import redispool=redis.ConnectionPool(host='192.168.1.126',port=6379,db=0)r = redis.StrictRedis(connection_pool=pool)print r.incr('age')print r.incrby('age',2)print r.incrbyfloat('fage', 12.1)print r.decr('age')print r.decr('age', 2)print r.incrbyfloat('fage', -2.1)