• Redis的散列类型


      Redis是采用字典结构以key-value的形式存储数据的,在散列类型(所谓的hash)中的value也是一种字典结构。如果用关系表结构去理解,就是key为对象,value是属性和属性值。如下图:

     

    所以使用散列(hash)类型,可以很方便的存储对象,值得注意的是,字段属性的值只能是字符串类型。

      对于一个传统的关系数据表,如下图:

    ID color name price model
    1 白色  梅赛德斯 98万 S级
    2 黑色 奥迪 90万  
    3 红色 凯迪拉克 80万  

     

    如果想在关系数据表为某一条记录单独添加属性,这是做不到的,只能够同时给其他记录也添加属性,如给ID为1的记录添加model属性,其他记录也具有了model属性,只是没有值,这里会出现问题,当记录数据非常多的时候,其他不需要model属性的记录就会出现属性冗余。同时,为一条记录去修改表的结构,也是一件非常不友好的行为。那么,使用redis的散列(hash)类型就可以完美解决这个问题,它可以自由地为任何键增减字段而不影响其他键。

    命令:赋值与取值

    HSET key field value

    redis> HSET car:1 price 98000
    (integer) 1
    redis> HSET car:1 name BMW
    (integer) 1

    HGET key field

    redis> HGET car:1 name
    "BMW"

    HMSET key field1 value1 [field2 value2 ...]

    redis> HMSET car:2 price 90000 name Audi

    HMGET key field1 [field2 ...]

    redis> HMGET car:2 price name
    1) "90000"
    2) "Audi"

    HGETALL key

    redis> HGETALL car:2
    1) "price"
    2) "90000"
    3) "name"
    4) "Audi"

      HSET的命令对于同一键名,不区分插入和更新操作,这意味着修改数据的时候不需要事先判断字段是否已经存在来决定是执行插入数据,还是更新数据。当执行插入操作,返回1,当执行更新操作,返回0。当键不存在时,HSET会自动创建,这个跟SET命令一样。

  • 相关阅读:
    K3CLOUD表关联
    QLIKVIEW基础设置及初步了解
    CLOUD信用管理设置
    QLIKVIEW添加数据库连接
    MRP没生成MRP汇总表
    金蝶学习网站
    CLOUD常用设置
    BZOJ 3551: [ONTAK2010]Peaks加强版 Kruskal重构树+dfs序+主席树+倍增
    BZOJ 3732: Network Kruskal 重构树
    LOJ #2718. 「NOI2018」归程 Dijkstra+可持久化并查集
  • 原文地址:https://www.cnblogs.com/SysoCjs/p/9999647.html
Copyright © 2020-2023  润新知