Redis指令组(三)
- 简介
- hash指令组
- HSET、HMSET
- HGET、HMGET、HGETALL
- HSETNX
- HDEL
- HEXISTS
- HINCRBY、HINCRBYFLOAT
- HKEYS
- HLEN
- HSTRLEN
- HVALS
- HSCAN
简介
本篇介绍redis中hash类型的指令组。
hash指令组
HSET、HMSET
hset: 设置key指定的hash中指定字段的值。
hmset: hset的多field版本。
HGET、HMGET、HGETALL
hget: 获取key中指定字段的值。
hmget: 获取key中指定的多个字段的值。
hgetall: 获取key中所有字段以及值。
HSETNX
hsetnx: 只在key指定的hash中不存在指定字段时,设置字段的值,否则设置失败。类比setnx。
HDEL
hdel: 删除key中指定的字段,若字段不存在则忽略。
HEXISTS
hexists: 返回key中是否包含指定的字段。
HINCRBY、HINCRBYFLOAT
hincrby: 增加key指定的hash中指定的字段的数值。
hincrbyfloat: hincrby的浮点值版本。
HKEYS
hkeys: 返回key指定的hash中的所有字段的名字。
HLEN
hlen: 返回 key 指定的哈希集包含的字段的数量。
HSTRLEN
hstrlen: 返回hash指定field的value的字符串长度,如果hash或者field不存在,返回0.
HVALS
hvals: 返回 key 指定的哈希集中所有字段的值。
HSCAN
hscan: 增量的获取一个集合的元素。
在获取大数据量的key时,如果使用keys命令的话可能会出现阻塞服务器的现象,keys会返回所有的符合条件的key。如果在生产环境阻塞服务器是绝对不允许的。
redis提供了一个scan指令可以增量的获取一个集合的元素。对于不同的value类型有不同的指令,但是工作方式类似。
- scan 命令用于增量获取数据库中key的集合。
- sscan 命令用于增量获取set集合的元素。
- hscan 命令用于增量获取hash类型的兼职对
- zscan 命令用于增量获取SortSet集合中的元素和元素对应的值。
scan命令是基于游标的,每次使用scan必须传入上一次调用scan返回的游标。首次调用scan游标必须为0。当scan再次返回的游标为0时,代表已经全部返回。
- 在整个遍历阶段,scan总是保证将一直存在于数据集内的所有元素都会被返回。
- scan可能会将某个元素返回多次。
- 如果一个元素在循环获取的过程中添加到数据集,又或者被删除,那么数据可能被返回也可能不会。
- 当scan指令返回0个元素但是游标不为0时,说明数据集里面还有值,需要继续调用scan直到返回的游标为0.
scan不保证每次调用都返回相同数量的元素,但是可以使用count选项进行调整。
- count参数默认值为10。
- 数据集比较大时,如果没有match选项,那么返回的数量n通常 n>=count
- 当编码为整数集合,压缩列表的小集合时,会无视count在第一次迭代就将所有的元素返回。
类似于keys命令,scan支持glob风格的参数模式。
MATCH功能对元素的模式匹配工作是在命令从数据集中取出元素后和向客户端返回元素前的这段时间内进行的, 所以如果被迭代的数据集中只有少量元素和模式相匹配, 那么迭代命令或许会在多次执行中都不返回任何元素。
当有多个客户端对同一个数据集调用scan时,客户端每次执行迭代都需要传入一个游标, 并在迭代执行之后获得一个新的游标, 而这个游标就包含了迭代的所有状态, 因此, 服务器无须为迭代记录任何状态。
因为服务端不保存任何循环状态,所以可以随时中断一个循环。
- scan命令返回每个的元素都是一个key
- sscan命令返回的每个元素都是一个集合成员。
- hscan命令返回的每个元素都是一个键值对。
- zscan命令返回的每个元素都是一个有序集合元素。