• Redis之hash类型


    Redis之hash类型

    在这里插入图片描述
    redis的hash类型,就像Java中的Map>

    1. 设置一个字段/获取一个字段

    设置一个字段:HSET key field value
    获取一个字段:HGET key field

    127.0.0.1:6379> hset user id 1
    (integer) 1
    127.0.0.1:6379> hget user id
    "1"
    
    • 1
    • 2
    • 3
    • 4

    2. 获取所有字段值

    HGETALL key

    127.0.0.1:6379> hgetall user
    1) "id"
    2) "1"
    
    • 1
    • 2
    • 3

    3. 判断字段是否存在

    HEXISTS key field
    存在返回1,不存在返回0.

    127.0.0.1:6379> hexists user id
    (integer) 1
    127.0.0.1:6379> hexists user name
    (integer) 0
    127.0.0.1:6379> hgetall user
    1) "id"
    2) "1"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    4. 设置多个字段/获取多个字段

    设置多个字段:HMSET key field value [field value …]
    获取多个字段:HMGET key field [field …]

    127.0.0.1:6379> hgetall user
    1) "id"
    2) "1"
    127.0.0.1:6379> hmset user name zhangsan address xian score 99
    OK
    127.0.0.1:6379> hmget user id name
    1) "1"
    2) "zhangsan"
    127.0.0.1:6379> hmget user id name address score
    1) "1"
    2) "zhangsan"
    3) "xian"
    4) "99"
    127.0.0.1:6379> hgetall user
    1) "id"
    2) "1"
    3) "name"
    4) "zhangsan"
    5) "address"
    6) "xian"
    7) "score"
    8) "99"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    5. 只获取字段名/字段值

    获取字段名:HKEYS key
    获取字段值:HVALS key

    127.0.0.1:6379> hgetall user
    1) "id"
    2) "1"
    3) "name"
    4) "zhangsan"
    5) "address"
    6) "xian"
    7) "score"
    8) "99"
    127.0.0.1:6379> hkeys user
    1) "id"
    2) "name"
    3) "address"
    4) "score"
    127.0.0.1:6379> hvals user
    1) "1"
    2) "zhangsan"
    3) "xian"
    4) "99"
    127.0.0.1:6379> hvals person
    (empty list or set)
    127.0.0.1:6379> hkeys person
    (empty list or set)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23

    6. 获取某个key内全部数量

    HLEN key

    127.0.0.1:6379> hgetall user
    1) "id"
    2) "1"
    3) "name"
    4) "zhangsan"
    5) "address"
    6) "xian"
    7) "score"
    8) "99"
    127.0.0.1:6379> hlen user
    (integer) 4
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    7. 增加数字

    HINCRBY key field increment

    127.0.0.1:6379> hget user id
    "1"
    127.0.0.1:6379> hincrby user id 5
    (integer) 6
    127.0.0.1:6379> hget user id
    "6"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    8. 删除key内字段

    HDEL key field

    127.0.0.1:6379> hgetall user
    1) "id"
    2) "6"
    3) "name"
    4) "zhangsan"
    5) "address"
    6) "xian"
    7) "score"
    8) "99"
    127.0.0.1:6379> hkeys user
    1) "id"
    2) "name"
    3) "address"
    4) "score"
    127.0.0.1:6379> hdel user address
    (integer) 1
    127.0.0.1:6379> hgetall user
    1) "id"
    2) "6"
    3) "name"
    4) "zhangsan"
    5) "score"
    6) "99"
    127.0.0.1:6379> hkeys user
    1) "id"
    2) "name"
    3) "score"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27

    9. 字段不存在时赋值

    HSETNX key field value

    127.0.0.1:6379> hkeys user
    1) "id"
    2) "name"
    3) "score"
    127.0.0.1:6379> hsetnx user address xian
    (integer) 1
    127.0.0.1:6379> hkeys user
    1) "id"
    2) "name"
    3) "score"
    4) "address"
    127.0.0.1:6379> hvals user
    1) "6"
    2) "zhangsan"
    3) "99"
    4) "xian"
    127.0.0.1:6379> hgetall user
    1) "id"
    2) "6"
    3) "name"
    4) "zhangsan"
    5) "score"
    6) "99"
    7) "address"
    8) "xian"
    127.0.0.1:6379> hsetnx user score 98
    (integer) 0
    127.0.0.1:6379> hgetall user
    1) "id"
    2) "6"
    3) "name"
    4) "zhangsan"
    5) "score"
    6) "99"
    7) "address"
    8) "xian"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36

    10. 应用场景

    • 购物车

    用户id为100的用户购物车,买了商品item1 1件, 商品item2 1件,然后增加商品item2 到4件,查看用户总共买了多少商品,每个商品分别是多少。

    127.0.0.1:6379> hset shopcar:uid100 item1 1
    (integer) 1
    127.0.0.1:6379> hset shopcar:uid100 item2 1
    (integer) 1
    127.0.0.1:6379> hincrby shopcar:uid100 item2 3
    (integer) 4
    127.0.0.1:6379> hlen shopcar:uid100
    (integer) 2
    127.0.0.1:6379> hgetall shopcar:uid100
    1) "item1"
    2) "1"
    3) "item2"
    4) "4"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
  • 相关阅读:
    史上最简单:SpringCloud 集成 mybatis-plus(以若依微服务版本为例)
    【Python仿真】基于EKF的传感器融合定位
    最新SQL注入漏洞原理及与MySQL相关的知识点
    Elasticsearch - DSL 查询语句
    【无标题】
    spring redis 工具类
    区域治理杂志区域治理杂志社区域治理编辑部2022年第40期目录
    NLP的不同研究领域和最新发展的概述
    k8s部署 多master节点负载均衡以及集群高可用
    大数据-之LibrA数据库系统告警处理(ALM-12047 网络读包错误率超过阈值)
  • 原文地址:https://blog.csdn.net/stormkai/article/details/133098833