list
1、list类型
list链表查询速度慢!
新的存储需求: 存储大量的数据,在查询方面提供更高的效率
需要的存储结构: 能够保存大量的数据,高效的内部存储机制,便于查询
set类型: 与hash存储结构完全相同,仅存储键,不存储值(nil),并且值是不允许重复的。
2、list类型基本操作
# 添加数据
sadd key member1 [member2]
# 获取全部数据
smembers key
# 删除数据
srem key member1 [member2]
# 获取集合数据总量
scard key
# 判断集合中是否包含指定数据
sismember key member
3、set 类型数据的扩展操作
3.1、随机操作数据
# 随机获取集合中指定数量的数据
srandmember key [count]
# 随机获取集合中的某个数据并将该数据移出集合
spop key [count]
3.2、set数据交并差操作
1、求两个集合的交、并、差集
# 交集 A∩B
sinter key1 [key2]
# 并集 A∪B
sunion key1 [key2]
# 差集 A-B A里面有B里面没有
sdiff key1 [key2]
2、求两个集合的交、并、差集并存储到指定集合中
# destination是一个存储的目的集合的
keysinterstore destination key1 [key2]
sunionstore destination key1 [key2]
sdiffstore destination key1 [key2]
3、将指定数据从原始集合中移动到目标集合中
smove source destination member
注意:差运算是有方向性的;
将u2中的w1移到u1中:
4、set 类型数据操作的注意事项
- set 类型不允许数据重复,如果添加的数据在 set 中已经存在,将只保留一份
- set 虽然与hash的存储结构相同,但是无法启用hash中存储值的空间
5、set 类型应用场景
5.1、权限校验
将每一个人的所有操作放到 以这个人为key,它的所有操作作为set的value,这样就能将相同的权限去掉。
以上两种校验方式,最好采用第一种,在业务层进行校验!
提供基础数据,在业务层进行校验结果!
5.2、网站访问数据统计
5.3、黑白名单