Redis-Hash型与List型操作命令

Hash型Value操作命令

Hash类型也称为Hash表、字典等。

Hash表就是一个映射表Map,也是由键值对构成,为了与Map区分,这里的键称为field,值称为value。

注意:Redis的Hash表中的field-value对均为String类型。

  • hset:将Hash表key中的域field 的值设为value,此命令也可以设置多个field-value。与hmset类似。

格式:hset key field value

注意:如果key不存在,一个新的Hash表被创建,然后进行hset操作。

​ 如果field已经存在,会覆盖旧值。

​ 如果field是Hash表中新建的,并且值设置成功,返回1;如果Hash表中field已经存在,并且旧值被覆盖,返回0。

hset employee name zhangsan age 22
  • hget:返回Hash表key 中给定域field 的值。

格式:hget key field

注意:如果给定域或者给定key不存在,则返回nil。

  • hmset:同时将多个field-value阈值对设置到Hash 表key中。

格式:hmset key field value [ field value ...]

注意:此命令会覆盖Hash表中已存在的域。

​ 如果key不存在,会创建一个空的Hash表,然后执行hmset操作。

​ 如果命令执行成功,返回ok。

​ 如果key 不是Hash类型,返回一个错误。

  • hmget:获取指定key 的Hash表中的多个field

格式:hmget key field 【field...】

  • hgetall:返回哈希表 key所有的 field-value 对,返回格式是交替排列的:field1, value1, field2, value2...

格式:hmget key

  • hkeys:获取Hash中 所有的field。

格式:hkeys key

  • hlen:获取hash中field的个数

格式:hlen key

  • hvals:获取hash中所有的value

格式:hvals key

  • hsetnx:仅当hash中的field不存在时,才会创建成功

格式:hsetnx key field value

  • hdel:删除hash中一个或多个field

格式:hdel key field 【field...】

  • hexists:判断hash中指定的field是否存在

格式:hexists key field

  • hincrby:给hash中指定的field 的value 加上指定的值,必须是整数,可以是负数。

格式:hincrby key field num

  • hincrbyfloat:给hash中指定的field 的value 加上指定的值,可以是小数,可以是负数。

格式:hincrbyfloatkey field num

  • hstrlen:获取hash中指定field 的value的字符串长度。

格式:hstrlen key field

应用场景

Hash型value适合存除对象数据。

key为属性名称,value为描述对象属性的map,对对象属性的修改在Redis中就可以直接完成。

不像String型Value存储对象,那个对象是序列化过的,要修改的话需要先反序列化为对象后再修改,

修改完后再序列化为json串后写入到Redis。

List型Value操作命令

Redis存储数据的value可以是一个String列表类型,即列表中的元素都是String类型。

列表的数据会按照插入顺序进行排序。

该列表的底层实际是一个无头节点的双向链表,所以对列表的头和尾操作性能比较高,但对中间元素的插入与删除的操作性能相对较差。

  • lpush/rpush:【lpush】将一个或多个值插入到列表key的表头;

​ 【rpush】将一个或多个值插入到列表key的表尾;

格式:lpush key value 【value...】 或者 rpush key value 【value...】

注意:如果有多个值,他们会将各个value按照从左到右的顺序依次插入到表头或表尾。

​ 如果key不存在,会创建一个空列表,然后进行操作。

  • lrange:返回列表中指定范围的元素,0表示第一个元素,-1表示最后一个元素

格式:lrange key start stop

  • llen:返回列表的长度

格式:llen key

  • lindex:查看list中某个索引的具体值

格式:lindex key index

  • lset:设置list中指定下标元素的值

格式:lset key index value

  • rpushx:向list中添加一个或多个值,这个list必须存在才可以添加成功!
  • rpush: 向list中添加一个或多个值,如果这个list不存在,会创建一个空list,然后添加元素。
  • linsert:向list中某个元素的前面/后面添加一个或多个值。

格式:linsert key before/after value value

  • lpop:从list中的头部弹出/删除 指定个数元素,不指定个数就默认弹出一个。
  • rpop:从list中的尾部弹出/删除 指定个数元素,不指定个数就默认弹出一个。
  • blpop/brpop:这是列表的阻塞式弹出命令,当列表中没有元素可弹出时,会阻塞连接,直到等待timeout超时或发现可弹出元素为止。当指定多个key时,按参数key的顺序一次检查各个列表,弹出第一个非空列表的头元素。timeout是阻塞时长,单位是秒,其值若为0,则表示若没有元素可弹出,就一直阻塞。

注意:如果在指定时间内没有任何元素被弹出,则返回一个bil和等待时长。

​ 反之,返回一个含有两个元素的列表,第一个元素是被弹出元素所属的key,第二个元素是被弹出元素的值。

  • rpoplpush:(rpoplpush source destination)一个原子时间内,执行以下两个动作:
    • 将source 列表中的尾元素弹出,并返回给客户端
    • 将source 中弹出的元素插入到列表destination 的头元素

注意:如果source 不存在,返回nil,不执行后面的操作。

​ 如果source 和destination相同·,则将列表的尾元素移动到头部,并返回该元素,这种情况视作列表的旋转操作。

  • brpoplpush: rpoplpush的阻塞版本。
  • lrem:lrem key count value

说明:根据count的值,移除列表中与value相等的元素,count的值可以是以下几种:

  1. count>0:从表头向表尾开始搜索,移除与value相等的元素,数量为count
  2. count<0:从表尾向表头开始搜索,移除与value相等的元素,数量为count的绝对值
  3. count=0:移除表中所有与value相等的值。

返回被移除元素的数量。

当key不存在,返回0。因为不存在的key被视作空表。

  • ltrim:对一个列表进行修剪,让list只保留指定区间内的元素,不在指定区间内的元素都将被删除。

格式:ltrim key start stop

注意:如果start大于列表的最大下标(llen list 减1),或者start>stop,则返回一个空列表,此时ltrim将列表清空了。

应用场景

list主要是通过构建不同的数据结构来实现相应的业务功能。

通过lpush+lpop实现栈的数据结构(先进后出。)

队列

通过lpush+rpop实现队列的数据结构(先进先出。)

阻塞式消息队列

通过lpush+brpop实现阻塞式消息队列效果。

消息生产者使用lpush从列表左侧插入数据。
brpop的timeout设置为0,表示只要没有数据可弹出,就永久阻塞。

消息消费者的多个客户端使用brpop阻塞式的“抢占”列表尾部数据进行消费,保证了消费的负载均衡与高可用性。

动态有限集合

通过lpush+ltrim实现阻塞式消息队列效果。

lpush从列表的左侧向列表中添加数据。

ltrim保持集合的动态有限性。

像企业的末位淘汰、学校的重点班等动态管理,都可以通过这种方式实现。

posted @ 2026-04-27 18:02  NE_STOP  阅读(12)  评论(0)    收藏  举报