这篇文章,我们开始学习set类型,学习set类型前我们先来看一下List类型有什么缺点。
List的缺点
当需要存储大量数据并且要提供高效率的查询时,List是无法完全实现的,这是因为list的存储结构是链表的形式,链表读取数据的效率是很低的,因此我们需要的存储结构就必须具备能够保存大量的数据,并且具有高效的内部存储机制,便于快速查询数据。这时我们一定就想到了hash类型,但是hash类型只是基本符合要求,我们知道hash类型是以key-value的形式存储的,那么我们可以说key也是数据,因此我们可以将key作为value来存储,而原本的value则设置为nil,这样我们就得到了本篇所讲的set类型,set类型是从hash类型言表而来的,因此set类型和hash类型具有相同的存储结果,但是数据仅存储在key(value)中。它的存储结构如下图所示:
Tip:set类型的值不允许重复
set类型基本操作
- 添加
假设我们有一个set类型的students集合,需要向里面添加一条或多条数据时,我们可以使用 sadd指令,语法是这样的sadd key member_1…member_n,例如向students中添加Anna,指令可以这么写sadd students Anna
。 - 获取全部数据
当我们要从students集合中获取全部学生时,可以使用 smembers指令,语法是这样的smembers key,查看全部选择可以这么写指令smembers students
- 删除数据
当一个学生转学后,就要从students集合中删除,这时我们可以使用srem,语法是这样的srem key member_1…member_n,例如要删除Jack这个学生,指令可以这么编写srem students Jack
- 获取集合数据总数
当我们需要获取学生的总数时,可以使用scard指令,语法是这样的scard key,获取学生数量的指令是这样的scard students
- 判断集合中是否包含指定的数据
在我们向students集合中插入数据前需要判断该数据是否存在于集合中,这是我们可以使用sismember指令,语法是这样的sismember key member,例如判断Tom是否存在于students中,指令可以这么编写sismember students Tom
小结
本篇文章主要讲解了List的缺点,以及Set的存储结构和set的基本操作指令。