redis的5种数据类型

àì夳堔傛蜴生んèń 2023-07-17 15:33 25阅读 0赞

一、String

1. 赋值:set key val
取值:get key val
删除key: del key
在这里插入图片描述

2. 一次给多个key赋值:mset key1 val1 key2 val2
一次获取多个key的值:mget key1 key2
在这里插入图片描述
这里注意:我用的是集群模式,在集群模式下不能直接使用mset和mget
在这里插入图片描述
3. 获取指定key的value的字符串长度:strlen
在这里插入图片描述

4. 追加字符串:append,返回追加后的字符串长度
在这里插入图片描述
在这里插入图片描述
在追加时,如果key不存在,则创建后再赋值
5. 指定key的加1操作:incr
在这里插入图片描述
指定key的增加的范围操作:incrby
如:让key的值增加5
在这里插入图片描述
指定key的值增加一个小数的操作:incrbyfloat
如:让key的值增加1.5
在这里插入图片描述
6. 指定的key的值的减1操作:decr
在这里插入图片描述
指定key的值减的范围的操作:decrby
如:让key的值减5
在这里插入图片描述
这里注意:
1.string在redis内部存储默认就是一个字符串,当遇到incr,decr操作时,会转成数值型进行计算
2.redis的所有操作都是原子性的,采用单线程处理业务,因此无需考虑并发带来的数据影响
3.安数值进行操作的数据,如果不能转成数值类型,或超越了redis数值上限范围将报错
9223372036854775807(java种Long行数据最大值,Long.MAX_VALUE)
4.数据最大存储量是512M

  1. 设置数据具有指定的生命周期
    setex key seconds value
    psetex key milliseconds value
    在这里插入图片描述
    在这里插入图片描述
    String类型应用场景:
    redis应用于各种结构型和非结构型高热度数据访问加速
    1.例如:在redis中为大V用户设定用户信息,以用户主键和属性值作为key,后台设置定时刷新策略即可。

    eg: user:id:12:fans ->123
    eg: user:id:12:blogs ->10

2.在redis中以json格式存储大V用户信息,定时刷新,也可以使用hash类型

  1. user:id:12 ->
  2. {id:12,name:weibo,fans:123}

key的设置约定:数据库中 的热点数据key命名惯例

  1. 表名:主键名:主键值:字段名
  2. eg: order:id:100:name

二、hash类型

新的存储需求:对一系列存储的数据进行编组,方便管理,典型应用存储对象信息。
需要的存储结构:一个存储空间内保存多个键值对数据。
hash类型:底层使用哈希表结构实现数据存储。

1. 添加修改数据
hset key field value
hmset key field1 value1 field2 value2
hsetnx key field val

2. 获取数据
hget key field
hmget key field1 field2
hgetall key
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
3. 删除数据
hdel key field1 field2
在这里插入图片描述

4. 获取指定key中的field的数量:hlen
在这里插入图片描述

5. 获取hash表中是否存在指定的field:hexists
在这里插入图片描述

6. 获取指定key的所有的fields或values
hkeys key
hvals key

  1. 121.36.79.125:6379> hkeys user
  2. -> Redirected to slot [5474] located at 121.36.29.155:6379
  3. 1) "name"
  4. 2) "age"
  5. 3) "weight"
  6. 121.36.79.125:6379> hvals user
  7. -> Redirected to slot [5474] located at 121.36.29.155:6379
  8. 1) "zhansan"
  9. 2) "18"
  10. 3) "100"

7. 设置指定字段的数据增加指定范围的值
hincrby key field increment
hincrbyfloat key field increment

  1. 121.36.79.125:6379> hincrby user age 2
  2. -> Redirected to slot [5474] located at 121.36.29.155:6379
  3. (integer) 20
  4. 121.36.29.155:6379> hget user age
  5. "20"
  6. 121.36.29.155:6379> hincrbyfloat user age 1.8
  7. "24.8"

注意事项:

每个hash可以存储2^32-1个键值对;
hash类型十分贴近对象的存储形式,并且可以灵活添加删除对象属性。但hash设计初衷不是为了存储大量对象而设计,切记不要滥用,更不可以将hash作为存储对象列表使用。
hgetall可以获取全部属性,如果内部field过多,遍历整体数据效率就会很低,有可能成为数据访问的瓶颈。

三、list类型

数据存储需求:存储多个数据,并对数据进入存储空间的顺序进行区分;
需要的存储结构:一个存储空间保存多个数据,且通过数据可以体现进入顺序;
list类型:保存多个数据,底层使用双向链表存储结构实现;

1. 添加/修改数据
lpush key value1 value2
rpush key value1 value2

2. 获取数据
lrange key start stop
lindex key index
llen key

  1. 121.36.79.125:6379> lpush list1 huawei apple micrsoft
  2. -> Redirected to slot [7141] located at 121.36.29.155:6379
  3. (integer) 3
  4. 121.36.29.155:6379> lrange list1 0 2
  5. 1) "micrsoft"
  6. 2) "apple"
  7. 3) "huawei"
  8. 121.36.29.155:6379> rpush list2 huawei apple micrsoft
  9. -> Redirected to slot [11142] located at 139.9.136.244:6379
  10. (integer) 3
  11. 139.9.136.244:6379> lrange list2 0 2
  12. 1) "huawei"
  13. 2) "apple"
  14. 3) "micrsoft"
  15. 139.9.136.244:6379> lrange list2 0 -1
  16. 1) "huawei"
  17. 2) "apple"
  18. 3) "micrsoft"
  19. 139.9.136.244:6379> lrange list2 0 -2
  20. 1) "huawei"
  21. 2) "apple"
  22. 139.9.136.244:6379> lindex list2 0
  23. 1) "huawei"
  24. 139.9.136.244:6379> lindex list2 1
  25. 1) "apple"
  26. 139.9.136.244:6379> llen list2
  27. (integer) 3

3. 获取并移除数据
lpop key
rpop key

  1. 121.36.29.155:6379> lpush list3 a b c
  2. -> Redirected to slot [11142] located at 139.9.136.244:6379
  3. (integer) 3
  4. 139.9.136.244:6379> lpop list3
  5. "c"
  6. 139.9.136.244:6379> llen list3
  7. (integer) 2
  8. 139.9.136.244:6379> lpop list3
  9. "b"
  10. 139.9.136.244:6379> lpop list3
  11. "a"
  12. 139.9.136.244:6379> lpop list3
  13. (nil)

4. 规定时间内获取并移除数据
blpop key1 key2 […] timeout
brpop key1 key2 […] timeout

  1. 139.9.136.244:6379> lpush list0 a b
  2. (integer) 2
  3. 139.9.136.244:6379> lpop list0
  4. "b"
  5. 139.9.136.244:6379> lpop list0
  6. "a"
  7. //另一个客户端放一个值:
  8. 139.9.136.244:6379> lpush list0 c
  9. (integer) 1
  10. 139.9.136.244:6379> blpop list0 10 //10秒内有数据进入的话就移除
  11. "c"

//也可以等待多个key,如果有数据进入就执行lpop

5. list类型数据扩展操作(右进左出)
移除指定数据:
lrem key count value

  1. 139.9.136.244:6379> rpush 001 a b c d e
  2. (integer) 5
  3. 139.9.136.244:6379> lrange 001 0 -1
  4. 1) "a"
  5. 2) "b"
  6. 3) "c"
  7. 4) "d"
  8. 5) "e"
  9. 139.9.136.244:6379> lrem 001 1 d
  10. 1) "a"
  11. 2) "b"
  12. 3) "c"
  13. 4) "e"
  14. 139.9.136.244:6379> rpush 001 a b c d a b c d
  15. (integer) 12
  16. 139.9.136.244:6379> lrange 001 0 -1
  17. 1) "a"
  18. 2) "b"
  19. 3) "c"
  20. 4) "e"
  21. 5) "a"
  22. 6) "b"
  23. 7) "c"
  24. 8) "d"
  25. 9) "a"
  26. 10) "b"
  27. 11) "c"
  28. 12) "d"
  29. 139.9.136.244:6379> lrem 001 2 a
  30. (integer) 2
  31. 139.9.136.244:6379> lrange 001 0 -1
  32. 1) "b"
  33. 2) "c"
  34. 3) "e"
  35. 4) "b"
  36. 5) "c"
  37. 6) "d"
  38. 7) "a"
  39. 8) "b"
  40. 9) "c"
  41. 10) "d"

list中的数据类型都是string的,数据总容量是有限的,最多2^32-1个元素;
list具有索引的概念,但是操作数据时通常以队列的形式进行入队出队操作,或以栈的形式进行入栈出栈操作。
获取全部数据操作结束索引设置为-1;
list可以对数据进行分页操作,通常第一页的信息来源于list,第2页以及更多的操作通过数据库的形式加载。

四、set类型

  1. 添加数据
    sadd key member1 [member2]
  2. 获取全部数据
    smembers key
  3. 删除数据
    srem key member1 member2

发表评论

表情:
评论列表 (有 0 条评论,25人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Redis常用5数据类型

    本文重要介绍,redis的五种数据类型,以及各应用场景 字符串string: 字符串类型是Redis中最为基础的数据存储类型,是一个由字节组成的序列,他在Redis中是