连接 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 设置值
2. r.get 获取值
3. mset 批量设置值
4. mget(keys, *args) 批量获取
5. getset 设置新值,打印原值
6. getrange 根据字节获取子序列
7. setrange 修改字符串内容,从指定字符串索引开始向后替换,如果新值太长时,则向后添加
8. strlen(name) 返回name对应值的字节长度
9. incr 值的累加 amount为累加的值
10. append 在name对应的值后面追加内容
11.type 查看类型
案例
页面点击数
假定我们对一系列页面需要记录点击次数。例如论坛的每个帖子都要记录点击次数,而点击次数比回帖的次数的多得多。如果使用关系数据库来存储点击,可能存在大量的行级锁争用。所以,点击数的增加使用redis的INCR命令最好不过了。
当redis服务器启动时,可以从关系数据库读入点击数的初始值(1237这个页面被访问了34634次)
每当有一个页面点击,则使用INCR增加点击数即可。
二、Hash 操作
redis中的Hash 在内存中类似于一个name对应一个dic来存储
1. hset name对应的hash中设置一个键值对(不存在,则创建,否则,修改)
2. hget 在name对应的hash中根据key获取value
3. hgetall 获取name对应hash的所有键值
4. hmset 在name对应的hash中批量设置键值对,mapping:字典
5. hmget 在name对应的hash中获取多个key的值
6.hlen 获取hash中键值对的个数
hkeys 获取hash中所有的key的值
hvals 获取hash中所有的value的值
7. hexists 检查name对应的hash是否存在当前传入的key
8. hdel 删除指定name对应的key所在的键值对
9. hincrby 自增hash中key对应的值,不存在则创建key=amount(amount为整数)
10.hincrbyfloat 自增hash中key对应的值,不存在则创建key=amount(amount为浮点数)
自增hash中key对应的值,不存在则创建key=amount(amount为浮点数)
hincrbyfloat(name, key, amount=1.0)
案例
使用hash类型保存多样化对象,类似二维表结构
当有大量类型文档的对象,文档的内容都不一样时,(即“表”没有固定的列),可以使用hash来表达。
三、List 操作
redis中的List在内存中按照一个name对应一个List来存储
1. lpush 在name对应的list中添加元素,每个新的元素都添加到列表的最左边
2.rpush 同lpush,但每个新的元素都添加到列表的最右边
3. lpushx 在name对应的list中添加元素,只有name已经存在时,值添加到列表的最左边
4. rpushx 在name对应的list中添加元素,只有name已经存在时,值添加到列表的最右边
5. llen name对应的list元素的个数
6. linsert 在name对应的列表的某一个值前或后插入一个新值
7. r.lset 对list中的某一个索引位置重新赋值
8. r.lrem 删除name对应的list中的指定值
9. lpop 移除列表的左侧第一个元素,返回值则是第一个元素
10. lindex 根据索引获取列表内元素
11. lrange 分片获取元素
12. ltrim 移除列表内没有在该索引之内的值(裁剪)
13. rpoplpush(src, dst) 从一个列表取出最右边的元素,同时将其添加至另一个列表的最左边
四、Set 操作
Set集合就是不允许重复的列表
1. sadd(name,values) 给name对应的集合中添加元素
2. smembers(name) 获取name对应的集合的所有成员
3. scard(name) 获取name对应的集合中的元素个数
4. sdiff(keys, *args) 在第一个name对应的集合中且不在其他name对应的集合的元素集合
5. sinter(keys, *args) 获取多个name对应集合的并集
6.sismember 检查value是否是name对应的集合内的元素
7. smove(src, dst, value) 将某个元素从一个集合中移动到另外一个集合
8. spop(name) 从集合的右侧移除一个元素,并将其返回
9. srandmember(name, numbers) 从name对应的集合中随机获取numbers个元素
10. srem(name, values) 删除name对应的集合中的某些值
11. sunion(keys, *args) 获取多个name对应的集合的并集
12. sunionstore(dest,keys, *args) 获取多个name对应的集合的并集,并将结果保存到dest对应的集合中
案例
社交圈子数据
在社交网站中,每一个圈子(circle)都有自己的用户群。通过圈子可以找到有共同特征(比如某一体育活动、游戏、电影等爱好者)的人。当一个用户加入一个或几个圈子后,系统可以向这个用户推荐圈子中的人。
我们定义这样两个圈子,并加入一些圈子成员。
获取一个圈子的成员
可以使用集合运算来得到几个圈子的共同成员:
五、有序集合 zset
有序集合:
在集合的基础上,为每元素排序,元素的排序需要根据另外一个值来进行比较,所以,对于有序集合,每一个元素有两个值,即:值和分数,分数专门用来做排序。
1. zadd(name, args, *kwargs)
2. zcard(name) 获取有序集合内元素的数量
3. zcount(name, min, max) 获取有序集合中分数在[min,max]之间的个数
4. zincrby(name, value, amount) 自增有序集合内value对应的分数
5. zrange( name, start, end, desc=False, withscores=False, score_cast_func=float)
6. zrevrange(name, start, end, withscores=False, score_cast_func=float)
7. zrank(name, value)、zrevrank(name, value)
8. zscore(name, value) 获取name对应有序集合中 value 对应的分数
9. zrem(name, values) 删除name对应的有序集合中值是values的成员
10. zremrangebyrank(name, min, max) 根据排行范围删除
11. zremrangebyscore(name, min, max) 根据分数范围删除
12. zinterstore(dest, keys, aggregate=None)
13. zunionstore(dest, keys, aggregate=None)
其他常用操作
1. delete(*names) 根据name删除redis中的任意数据类型
2. exists(name) 检测redis的name是否存在
3. keys(pattern='*') 根据* ?等通配符匹配获取redis的name
4. expire(name ,time) 为某个name设置超时时间
5. rename(src, dst) 重命名
6. move(name, db)) 将redis的某个值移动到指定的db下
7. randomkey() 随机获取一个redis的name(不删除)
8. type(name) 获取name对应值的类型
来源:https://segmentfault.com/a/1190000015191422
閱讀更多 Python學習 的文章