redis数据类型
String(字符串)
用途:存储字符串类型的数据,例如缓存数据、用户会话、简单的键值对等。
Hash(哈希)
用途:以键值对的形式存储数据,适合存储对象、用户属性等结构化数据。比如存储用户信息、文章信息等。
List(列表)
用途:有序存储多个字符串元素,适合实现消息队列、任务列表等场景。例如存储聊天消息记录、新闻队列等。
Set(集合)
用途:存储不重复、无序的字符串集合,适合进行成员关系判断、去重等操作。比如存储用户的兴趣标签、社交关系等。
Sorted Set(有序集合)
用途:类似 Set,但每个元素都关联一个分数,使得集合中的元素可以按照分数进行排序。适合按分数范围获取元素、排行榜等场景。例如存储用户积分排行榜、帖子的热度排行等。
Bitmap(位图)
用途:可以进行位操作的数据结构,适合存储布尔值数组、统计数据等场景。如存储用户签到信息、在线状态等。
HyperLogLog(基数估计)
用途:用于基数统计的数据结构,适合统计独立用户访问数量、页面浏览次数等。比如统计网站的独立访客数、活跃用户数等。
Geo(地理位置)
用途:存储地理位置信息,并支持距离计算、位置范围查询等操作。适合实现周边搜索、地理位置距离计算等。例如存储商家位置、附近的人等。
操作之String操作
from redis import Redis
conn = Redis(host='192.168.0.2', port=6379)
set(name, value, ex=None, px=None, nx=False, xx=False)
在Redis中设置值,默认,不存在则创建,存在则修改
参数:
ex,过期时间(秒)
px,过期时间(毫秒)
nx,如果设置为True,则只有name不存在时,当前set操作才执行,值存在,就修改不了,执行没效果
xx,如果设置为True,则只有name存在时,当前set操作才执行,值存在才能修改,值不存在,不会设置新值
# 例
conn.set('name', 'jsd')
setnx(name, value)
# 设置值,只有name不存在时,执行设置操作(添加),如果存在,不会修改
# 等同于
conn.set('name', 'jsd', nx=True)
setex(name, value, time)
# 设置值
# 参数:
# time,过期时间(数字秒 或 timedelta对象)
# 例
conn.setex('name', 3, 'jsd')
# 等同于:
conn.set('name', 'jsd', ex=3)
psetex(name, time_ms, value)
# 设置值
# 参数:
# time_ms,过期时间(数字毫秒 或 timedelta对象)
# 就是把过期时间由秒改为以毫秒为单位
**mset(*args, kwargs)
批量设置值
如:
conn.mset(k1='v1', k2='v2')
或
conn.mset({'k1': 'v1', 'k2': 'v2'})
get(name)
# 获取保存在redis中的值,如果取不到返回None
# 返回格式为bytes类型、
conn.set('name', '好好学习', 3)
print(str(conn.get('name'), encoding='utf-8')) # 可以使用str直接转换
*mget(keys, args)
# 批量获取多个值
# 如:
conn.mget('k1', 'k2')
或
conn..mget(['k3', 'k4'])
# 上面两种返回的结果是一样的,并且都是bytes类型
getset(name, value)
# 设置新值并获取原来的值
conn.set('name', 'jsd')
print(conn.getset('name', 'dsj')) # 先获取到 'jsd' 再把dsj设置进去
print(conn.get('name')) # 此时再获取的值就变为了 'jsd'
getrange(key, start, end)
# 获取子序列(根据字节获取,非字符)
# 参数:
# name,Redis 的 name
# start,起始位置(字节)
# end,结束位置(字节)
# 如: "彭于晏" ,0-3表示 "彭"
setrange(name, offset, value)
# 修改字符串内容,从指定字符串索引开始向后替换(新值太长时,则向后添加)
# 参数:
# offset,字符串的索引,字节(一个汉字三个字节)
# value,要设置的值
setbit(name, offset, value)
# 对name对应值的二进制表示的位进行操作
# 参数:
# name,redis的name
# offset,位的索引(将值变换成二进制后再进行索引)
# value,值只能是 1 或 0
# 注:如果在Redis中有一个对应: n1 = "foo",
那么字符串foo的二进制表示为:01100110 01101111 01101111
所以,如果执行 setbit('n1', 7, 1),则就会将第7位设置为1,
那么最终二进制则变成 01100111 01101111 01101111,即:"goo"
getbit(name, offset)
# 获取name对应的值的二进制表示中的某位的值 (0或1)
bitcount(key, start=None, end=None)
# 获取name对应的值的二进制表示中 1 的个数
# 参数:
# key,Redis的name
# start,位起始位置
# end,位结束位置
*bitop(operation, dest, keys)
# 获取多个值,并将值做位运算,将最后的结果保存至新的name对应的值
# 参数:
# operation,AND(并) 、 OR(或) 、 NOT(非) 、 XOR(异或)
# dest, 新的Redis的name
# *keys,要查找的Redis的name
# 如:
bitop("AND", 'new_name', 'n1', 'n2', 'n3')
# 获取Redis中n1,n2,n3对应的值,然后讲所有的值做位运算(求并集),然后将结果保存 new_name 对应的值中
strlen(name)
# 返回name对应值的字节长度(一个汉字3个字节)
incr(self, name, amount=1)
# 自增 name对应的值,当name不存在时,则创建name=amount,否则,则自增。
# 参数:
# name,Redis的name
# amount,自增数(必须是整数)
# 注:同incrby
# 可以用来计数
incrbyfloat(self, name, amount=1.0)
# 自增 name对应的值,当name不存在时,则创建name=amount,否则,则自增。
# 参数:
# name,Redis的name
# amount,自增数(浮点型)
decr(self, name, amount=1)
# 自减 name对应的值,当name不存在时,则创建name=amount,否则,则自减。
# 参数:
# name,Redis的name
# amount,自减数(整数)(可以为负数)
append(key, value)
# 在redis name对应的值后面追加内容
# 参数:
key, redis的name
value, 要追加的字符串