Python 操作 redis

连接 Redis

import

redis

连接方式:redis提供了2个方法

1:StrictRedis:实现大部分官方的命令

2:Redis:是StrictRedis的子类,用于向后兼容旧版的redis。

官方推荐使用StrictRedis方法。

举例(普通连接):

import redis

#decode_responses=True 自动解码

r = redis.Redis(host='127.0.0.1',port=6379,password='123456',db=0,decode_responses=True) #默认数据库为0

r = redis.StrictRedis(host='10.10.2.14',port=6379,password='123456',decode_responses=True)

连接池:connection pool

管理对一个redis server的所有连接,避免每次建立,释放连接的开销。默认,每个redis实例都会维护一个自己的连接池,可以直接建立一个连接池,作为参数传给redis,这样可以实现多个redis实例共享一个连接池。

举例(连接池):

pool = redis.ConnectionPool(host='127.0.0.1',port=6379,password='123456',decode_responses=True

)

r = redis.Redis(connection_pool=pool)

一 、STRING 字符串的操作

1. r.set 设置值

Python 操作 redis

2. r.get 获取值

Python 操作 redis

3. mset 批量设置值

Python 操作 redis

4. mget(keys, *args) 批量获取

Python 操作 redis

5. getset 设置新值,打印原值

Python 操作 redis

6. getrange 根据字节获取子序列

Python 操作 redis

7. setrange 修改字符串内容,从指定字符串索引开始向后替换,如果新值太长时,则向后添加

Python 操作 redis

8. strlen(name) 返回name对应值的字节长度

Python 操作 redis

9. incr 值的累加 amount为累加的值

Python 操作 redis

10. append 在name对应的值后面追加内容

Python 操作 redis

11.type 查看类型

Python 操作 redis

案例

页面点击数

假定我们对一系列页面需要记录点击次数。例如论坛的每个帖子都要记录点击次数,而点击次数比回帖的次数的多得多。如果使用关系数据库来存储点击,可能存在大量的行级锁争用。所以,点击数的增加使用redis的INCR命令最好不过了。

​ 当redis服务器启动时,可以从关系数据库读入点击数的初始值(1237这个页面被访问了34634次)

Python 操作 redis

每当有一个页面点击,则使用INCR增加点击数即可。

Python 操作 redis

二、Hash 操作

redis中的Hash 在内存中类似于一个name对应一个dic来存储

1. hset name对应的hash中设置一个键值对(不存在,则创建,否则,修改)

Python 操作 redis

2. hget 在name对应的hash中根据key获取value

Python 操作 redis

3. hgetall 获取name对应hash的所有键值

Python 操作 redis

4. hmset 在name对应的hash中批量设置键值对,mapping:字典

Python 操作 redis

5. hmget 在name对应的hash中获取多个key的值

Python 操作 redis

6.hlen 获取hash中键值对的个数

hkeys 获取hash中所有的key的值

hvals 获取hash中所有的value的值

Python 操作 redis

7. hexists 检查name对应的hash是否存在当前传入的key

Python 操作 redis

8. hdel 删除指定name对应的key所在的键值对

Python 操作 redis

9. hincrby 自增hash中key对应的值,不存在则创建key=amount(amount为整数)

Python 操作 redis

10.hincrbyfloat 自增hash中key对应的值,不存在则创建key=amount(amount为浮点数)

自增hash中key对应的值,不存在则创建key=amount(amount为浮点数)

hincrbyfloat(name, key, amount=1.0)

案例

使用hash类型保存多样化对象,类似二维表结构

当有大量类型文档的对象,文档的内容都不一样时,(即“表”没有固定的列),可以使用hash来表达。

Python 操作 redis

三、List 操作

redis中的List在内存中按照一个name对应一个List来存储

1. lpush 在name对应的list中添加元素,每个新的元素都添加到列表的最左边

Python 操作 redis

2.rpush 同lpush,但每个新的元素都添加到列表的最右边

Python 操作 redis

3. lpushx 在name对应的list中添加元素,只有name已经存在时,值添加到列表的最左边

Python 操作 redis

4. rpushx 在name对应的list中添加元素,只有name已经存在时,值添加到列表的最右边

Python 操作 redis

5. llen name对应的list元素的个数

Python 操作 redis

6. linsert 在name对应的列表的某一个值前或后插入一个新值

Python 操作 redis

7. r.lset 对list中的某一个索引位置重新赋值

Python 操作 redis

8. r.lrem 删除name对应的list中的指定值

Python 操作 redis

9. lpop 移除列表的左侧第一个元素,返回值则是第一个元素

Python 操作 redis

10. lindex 根据索引获取列表内元素

Python 操作 redis

11. lrange 分片获取元素

Python 操作 redis

12. ltrim 移除列表内没有在该索引之内的值(裁剪)

Python 操作 redis

13. rpoplpush(src, dst) 从一个列表取出最右边的元素,同时将其添加至另一个列表的最左边

Python 操作 redis

四、Set 操作

Set集合就是不允许重复的列表

1. sadd(name,values) 给name对应的集合中添加元素

Python 操作 redis

2. smembers(name) 获取name对应的集合的所有成员

Python 操作 redis

3. scard(name) 获取name对应的集合中的元素个数

Python 操作 redis

4. sdiff(keys, *args) 在第一个name对应的集合中且不在其他name对应的集合的元素集合

Python 操作 redis

5. sinter(keys, *args) 获取多个name对应集合的并集

Python 操作 redis

6.sismember 检查value是否是name对应的集合内的元素

Python 操作 redis

7. smove(src, dst, value) 将某个元素从一个集合中移动到另外一个集合

Python 操作 redis

8. spop(name) 从集合的右侧移除一个元素,并将其返回

Python 操作 redis

9. srandmember(name, numbers) 从name对应的集合中随机获取numbers个元素

Python 操作 redis

10. srem(name, values) 删除name对应的集合中的某些值

Python 操作 redis

11. sunion(keys, *args) 获取多个name对应的集合的并集

Python 操作 redis

12. sunionstore(dest,keys, *args) 获取多个name对应的集合的并集,并将结果保存到dest对应的集合中

Python 操作 redis

案例

社交圈子数据

在社交网站中,每一个圈子(circle)都有自己的用户群。通过圈子可以找到有共同特征(比如某一体育活动、游戏、电影等爱好者)的人。当一个用户加入一个或几个圈子后,系统可以向这个用户推荐圈子中的人。

​ 我们定义这样两个圈子,并加入一些圈子成员。

Python 操作 redis

获取一个圈子的成员

Python 操作 redis

可以使用集合运算来得到几个圈子的共同成员:

Python 操作 redis

五、有序集合 zset

有序集合:

在集合的基础上,为每元素排序,元素的排序需要根据另外一个值来进行比较,所以,对于有序集合,每一个元素有两个值,即:值和分数,分数专门用来做排序。

1. zadd(name, args, *kwargs)

Python 操作 redis

2. zcard(name) 获取有序集合内元素的数量

Python 操作 redis

3. zcount(name, min, max) 获取有序集合中分数在[min,max]之间的个数

Python 操作 redis

4. zincrby(name, value, amount) 自增有序集合内value对应的分数

Python 操作 redis

5. zrange( name, start, end, desc=False, withscores=False, score_cast_func=float)

Python 操作 redis

6. zrevrange(name, start, end, withscores=False, score_cast_func=float)

Python 操作 redis

7. zrank(name, value)、zrevrank(name, value)

Python 操作 redis

8. zscore(name, value) 获取name对应有序集合中 value 对应的分数

Python 操作 redis

9. zrem(name, values) 删除name对应的有序集合中值是values的成员

Python 操作 redis

10. zremrangebyrank(name, min, max) 根据排行范围删除

Python 操作 redis

11. zremrangebyscore(name, min, max) 根据分数范围删除

Python 操作 redis

12. zinterstore(dest, keys, aggregate=None)

Python 操作 redis

13. zunionstore(dest, keys, aggregate=None)

Python 操作 redis

其他常用操作

1. delete(*names) 根据name删除redis中的任意数据类型

Python 操作 redis

2. exists(name) 检测redis的name是否存在

Python 操作 redis

3. keys(pattern='*') 根据* ?等通配符匹配获取redis的name

Python 操作 redis

4. expire(name ,time) 为某个name设置超时时间

Python 操作 redis

5. rename(src, dst) 重命名

Python 操作 redis

6. move(name, db)) 将redis的某个值移动到指定的db下

Python 操作 redis

7. randomkey() 随机获取一个redis的name(不删除)

Python 操作 redis

8. type(name) 获取name对应值的类型

Python 操作 redis

来源:https://segmentfault.com/a/1190000015191422


分享到:


相關文章: