时间:2021-07-01 10:21:17 帮助过:22人阅读
hash表现形式上有些像python中的dict,可以存储一组关联性较强的数据,redis中Hash在内存中的存储格式如下图:
#name对应的hash中设置一个键值对(不存在,则创建;否则,修改)
#参数:
#name,redis的name
#key,name对应的hash中的key
#vale,name对应的Hash中的value
#如:
127.0.0.1:6379> hset fle1 k1 2
(integer) 1
#在name对应的Hash中批量设置键值对
#参数:
#name,redis的name
#mapping,字典,如:{'k1':'v1','k2':'v2'}
#如:
127.0.0.1:6379> hmset fle2 k1 3 k2 4 k3 5
OK
#在name对应的hash中获取多个key的值
#如:
hget fle2 k1
"3"
#在name对应的hash中获取多个key的值
#参数:
#name:redis对应的name
#keys,要获取key集合
#*args,要获取的Key
#如:
hmget fle2 k1 k2 k3
1) "3"
2) "4"
3) "5"
#获取name对应hash的所有键值
#获取name对应的hash中键值对的个数
127.0.0.1:6379> hlen fle2
(integer) 3
#获取name对应的hash中所有的key的值
如:
127.0.0.1:6379> hkeys fle2
1) "k1"
2) "k2"
3) "k3"
#获取name对应的hash中所有的value的值
如:
127.0.0.1:6379> hvals fle2
1) "3"
2) "4"
3) "5"
#检查name对应的hash是否存在当前传入的key
#存在返回1,不存在返回0
如:
127.0.0.1:6379> hexists fle2 k2
(integer) 1
127.0.0.1:6379> hexists fle2 y
(integer) 0
#将name对应的hash中指定key的键值对删除
如:
127.0.0.1:6379> hdel fle2 k2
(integer) 1
127.0.0.1:6379> hexists fle2 k2
(integer) 0
#自增name对应的值,当name不存在时,则创建name=amount,否则,则自增
如:
27.0.0.1:6379> incrbyfloat k2 1
"1"
127.0.0.1:6379>
127.0.0.1:6379> incrbyfloat k2 1
"2"
127.0.0.1:6379> incrbyfloat k2 1
"3"
#自增name对应的hash中的指定key的值,不存在则创建key=amount
#参数:
#name,redis中的name
#key,hash对应的key
#amount,自增数(浮点数)
#自增name对应的hash中的指定key的值,不存在则创建key=amount
#利用yield封装hscan创建生成器,实现分批去redis中获取数据
#参数:
#match,匹配指定key,默认None表示所有的key
#count,每次分片最少获取个数,默认None表示采用Redis的默认分片个数
list操作,redis中的List在内存中按照一个name对应一个List来存储,如图:
#在name对应的list中添加元素,每个新的元素都添加到列表的最左端
#如:
lpush bb 1 2 3 4
(integer) 4
#保存顺序:4 3 2 1
#扩展:
#rpush(name,values)表示从右向左操作
#在name对应的list中添加元素,只有name已经存在时,值添加到列表的最左边
#更多:
#rpushx(name,value)表示从右向左操作
#如:
127.0.0.1:6379> lpushx bb 5
(integer) 5
#name对应的list元素个数
#在name对应 的列表的某个值前或后插入一个新值
#参数:
#name,redis的name
#where,BEFOR或AFTER
#refvalue,标杆值,即:在它前后插入数据
#value,要插入的数据
#如:
127.0.0.1:6379> linsert bb before 5 8
(integer) 6
#name对应的List中的某一个索引位置重新赋值
#参数:
#name,redis的name
#index,list的索引位置
#value,要设置的值
#如:
27.0.0.1:6379> lset bb 3 90
OK
#在name对应的list中删除指定的值
#参数:
#name,redis的name
#value,要删除的值
#num,num=0,删除列表中所有的指定值;
#num=2,从前到后,删除2个
#num=-2,从后向前,删除2个
#在name对应的列表左侧获取第一个元素并在列表中移除,返回值则是第一个元素
#更多:
#rpop(name)表示从右向左操作
在name对应的列表中根据索引获取列表元素
#在name对应的列表分片获取数据
#参数:
#name,redis的name
#start,索引的起始位置
#end,索引结束位置
#在name对应的列表中移除没有在start-end索引之间的值
#参数:
#name,redis的name
#start,索引的起始位置
#end,索引结束位置
# 从一个列表取出最右边的元素,同时将其添加至另一个列表的最左边
# 参数:
# src,要取数据的列表的name
# dst,要添加数据的列表的name
# 将多个列表排列,按照从左到右去pop对应列表的元素
# 参数:
# keys,redis的name的集合
# timeout,超时时间,当元素所有列表的元素获取完之后,阻塞等待列表内有数据的时间(秒), 0 表示永远阻塞
# 更多:
# r.brpop(keys, timeout),从右向左获取数据
# 从一个列表的右侧移除一个元素并将其添加到另一个列表的左侧
# 参数:
# src,取出并要移除元素的列表对应的name
# dst,要插入元素的列表对应的name
# timeout,当src对应的列表中没有数据时,阻塞等待其有数据的超时时间(秒),0 表示永远阻塞
set操作,set集合就是不允许重复的列表
#对应的集合中添加元素
https://www.cnblogs.com/alex3714/articles/6217453.html
redis缓存数据库Hash,list,set操作
标签:rgs tno time ash 自增 批量 setname code img