首页 > 数据库 >【Redis】散列表(Hash)和列表(List)的运用和理解以及Hash和List应用场景对比详解

【Redis】散列表(Hash)和列表(List)的运用和理解以及Hash和List应用场景对比详解

时间:2022-11-10 23:31:24浏览次数:39  
标签:127.0 Hash 0.1 Redis List 列表 6379 哈希

一. 散列表(hash)

在这里插入图片描述

Redis哈希是字符串类型字段和值的映射表。哈希特别适合存储对象。 Redis中的每个哈希可以存储232-1个键值对(超过40亿)。

image-20221029130442831

1.1 基本操作

image-20221029130541652

image-20221029130754388

Redis Hset 命令用于为哈希表中的字段赋值 。如果哈希表不存在,一个新的哈希表被创建并进行 HSET 操作。如果字段已经存在于哈希表中,旧值将被覆盖。

Redis Hget 命令用于返回哈希表中指定字段的值。

hmget命令用于返回哈希表中指定多个的字段的值。

hgetall命令用于返回哈希表中所有的字段和值。

我的实操过程如下:

127.0.0.1:6379> hset h1 f1 v1 f2 v2
(integer) 2
127.0.0.1:6379> hget h1 f1
"v1"
127.0.0.1:6379> hmget h1 f1 f2
1) "v1"
2) "v2"
127.0.0.1:6379> hgetall h1
1) "f1"
2) "v1"
3) "f2"
4) "v2"

Redis Hkeys 命令用于获取哈希表中的所有域(field)。包含哈希表中所有域(field)列表。 当 key 不存在时,返回一个空列表。

Redis Hexists 命令用于查看哈希表的指定字段是否存在。如果哈希表含有给定字段,返回 1 。 如果哈希表不含有给定字段,或 key 不存在,返回 0 。

我的实操过程如下:

127.0.0.1:6379> hkeys h1
1) "f1"
2) "f2"
127.0.0.1:6379> hexists h1 f3
(integer) 0
127.0.0.1:6379> hstrlen h1 f1
(integer) 2

1.2 当value字符串的内容是数字时

image-20221029131302089

上篇文章里提到的字符串里也是可以加小数的。

如下,这个例子是增加一个f1字段的值为123,让其增加1.23,观察得知,最后的结果为"124.23"。

我的实操过程如下:

127.0.0.1:6379> hset h2 f1 123
(integer) 1
127.0.0.1:6379> hincrbyfloat h2 f1 1.23
"124.23"

二.列表(List)

Redis列表是一个简单的字符串列表,根据插入顺序排序。您可以将元素添加到列表的头部(左侧)或尾部(右侧) 一个列表最多可以包含232-1个元素(4294967295,每个列表超过40亿个元素)。

image-20221029131844892

2.1 基本操作

image-20221029132818387

Redis Rpush 命令用于将一个或多个值插入到列表的尾部(最右边)。如果列表不存在,一个空列表会被创建并执行 RPUSH 操作。 当列表存在但不是列表类型时,返回一个错误。**注意:**在 Redis 2.4 版本以前的 RPUSH 命令,都只接受单个 value 值。

Redis Lrange 返回列表中指定区间内的元素,区间以偏移量 START 和 END 指定。 其中 0 表示列表的第一个元素, 1 表示列表的第二个元素,以此类推。 你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。

Redis Lpush 命令将一个或多个值插入到列表头部。 如果 key 不存在,一个空列表会被创建并执行 LPUSH 操作。 当 key 存在但不是列表类型时,返回一个错误。**注意:**在Redis 2.4版本以前的 LPUSH 命令,都只接受单个 value 值。

我的实操过程如下:

127.0.0.1:6379> rpush li 1 2 3 4 5
(integer) 5
127.0.0.1:6379> lrange l1 0 -1
(empty array)
127.0.0.1:6379> lrange li 0 -1
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
127.0.0.1:6379> lpush li a b c d e
(integer) 10
127.0.0.1:6379> lrange li 0 -1
 1) "e"
 2) "d"
 3) "c"
 4) "b"
 5) "a"
 6) "1"
 7) "2"
 8) "3"
 9) "4"
10) "5"

Redis Rpop 命令用于移除列表的最后一个元素,返回值为移除的元素。

弹出之后,原本的列表里就不存在这个数值了。

我的实操过程如下:

127.0.0.1:6379> lrange li 0 -1
1) "e"
2) "d"
3) "c"
4) "b"
5) "a"
6) "1"
7) "2"
8) "3"
127.0.0.1:6379> rpop li
"3"

image-20221029133409386

Redis Lset 通过索引来设置元素的值。当索引参数超出范围,或对一个空列表进行 LSET 时,返回一个错误。

这里的例子将li的值从e改为了aa。

我的实操过程如下:

127.0.0.1:6379> lset li 0 aa
OK
127.0.0.1:6379> lrange li 0 -1
1) "aa"
2) "d"
3) "c"
4) "b"
5) "a"
6) "1"
7) "2"

Redis Linsert 命令用于在列表的元素前或者后插入元素。当指定元素不存在于列表中时,不执行任何操作。当列表不存在时,被视为空列表,不执行任何操作。如果 key 不是列表类型,返回一个错误。

如果命令执行成功,返回插入操作完成之后,列表的长度。 如果没有找到指定元素 ,返回 -1 。 如果 key 不存在或为空列表,返回 0 。

我的实操过程如下:

127.0.0.1:6379> linsert li after c cc
(integer) 8
127.0.0.1:6379> lrange li 0 -1
1) "aa"
2) "d"
3) "c"
4) "cc"
5) "b"
6) "a"
7) "1"
8) "2"

Redis Lrem 根据参数 COUNT 的值,移除列表中与参数 VALUE 相等的元素。

COUNT 的值可以是以下几种:

  • count > 0 : 从表头开始向表尾搜索,移除与 VALUE 相等的元素,数量为 COUNT 。
  • count < 0 : 从表尾开始向表头搜索,移除与 VALUE 相等的元素,数量为 COUNT 的绝对值。
  • count = 0 : 移除表中所有与 VALUE 相等的值。
127.0.0.1:6379> lrem li 2 c
(integer) 1

Redis Lrange 返回列表中指定区间内的元素,区间以偏移量 START 和 END 指定。 其中 0 表示列表的第一个元素, 1 表示列表的第二个元素,以此类推。 你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。

我的实操过程如下:

127.0.0.1:6379> lrange li 0 -1
1) "aa"
2) "d"
3) "cc"
4) "b"
5) "a"
6) "1"
7) "2"
127.0.0.1:6379> ltrim li 1 -2
OK
127.0.0.1:6379> lrange li 0 -1
1) "d"
2) "cc"
3) "b"
4) "a"
5) "1"

三.Hash和List的应用场景

3.1Hash的应用场景

1.对象缓存 哈希类型(键、字段、值)的结构类似于对象(对象id、属性、值),也可以用于存储对象。string+json也是一种存储对象的方法,

2. 购物车

3.2List的应用场景

  • 堆栈:LPUSH+LPOP-->FILO

    先入后出原则:LPUSH从队列左侧进入d、c、b、a,LPOP从队列左侧离开a、b、c、d

  • 队列:LPUSH+RPOP 先进先出原则:LPUSH从队列左侧进入d、c、b、a,RPOP从队列右侧离开d、c,b、a

  • 阻塞队列:LPUSH+BRPOP LPUSH+BRPOP在LPUSH+RPOP的基础上增加了阻塞和等待功能, BRPOP实际上等于阻塞+RPOP。当队列中的数据为空时, 它将侦听消息队列,直到收到消息

标签:127.0,Hash,0.1,Redis,List,列表,6379,哈希
From: https://blog.51cto.com/u_15568258/5842358

相关文章

  • 玩转微信小程序 之 获取用户信息以及玩转基本列表渲染(2019/04/14)
    LZ-Says:总是要各种颠沛流离,才能换得片刻安宁。努力让自己变得更好,加油~前言前几天,完成了微信小程序的首章,学习起来,还是多多少少有点坑,不舒服。今天我们继续开启微信小程序......
  • servlet实操之监听器Listener
    监听器实现一个监听器的接口:1、编写一个监听器publicclassOnlineCountListenerimplementsHttpSessionListener{//创建session的监听@Overridepubli......
  • 浅析WeakHashMap
    在Java或者是Android编程中,我们一般都会使用到Map,比如HashMap这样的具体实现。更高级一点,我们可能会使用WeakHashMap。WeakHashMap其实和HashMap大多数行为是一样的,只是Weak......
  • Android Study之总结使用ListView时需要去除相关效果的属性
    LZ-Says:各种忙啊。。。话说虽然之前推出一个RecyclerView替代了ListView以及GirdView,但是ListView依旧是ListView,掌握点相关知识多少还是有点用处的。使用ListView时,不免......
  • Redis数据结构简介-Hash
     Hash结构存储值与结构读写能力:包含键值对的无序散列表添加,获取,移除单个键值对;获取所有键值对.存储类似HashMap的数据 hash是日常开发过......
  • Redis数据结构简介-List
     List结构存储值与结构读写能力:一个链表,链表上的每个节点都包含了一个字符串从链表的两端推入或者弹出元素;根据偏移量对链表进行修剪(trim);读取单......
  • Redis 中 hash 扩容与缩容
    Redis中hash扩容与缩容当哈希表中元素数量逐渐增加时,此时产生hash冲突的概率逐渐增大,且由于dict也是采用拉链法解决hash冲突的,随着hash冲突概率上升,链表会越来越......
  • vue实现音频列表,播放互斥
    用了最暴力的方法,直接遍历。先判断是否是需要播放的音频,不是的话再判断它是否正在播放,是的话就关掉这条音频。没什么逻辑可言,但是不知道怎么控制这条音频关闭,花了点时间写......
  • 【java八股】ArrayList自动扩容过程
    ArrayList是一个数组类型的存储容器,默认大小是10个容量的数组,容量也可以在构件ArrayList的时候通过构造器指定大小,当容量不够时会进行自动扩容到原来的1.5倍,由于底层是数组......
  • IT25589: LIST HISTORY COMMAND FAILS WITH DB21018E ERROR WHEN THE HISTORY FILE CO
    KnownIssues https://www.ibm.com/mysupport/s/defect/aCI3p000000kF7p/dt159458?language=en_USIT25589:LISTHISTORYCOMMANDFAILSWITHDB21018EERRORW......