Redis数据类型之HASH类型

Web程序猿博客:http://blog.csdn.net/thinkercode

HASH类型-特点

Redis hash 是一个 string 类型的 field 和 value 的映射表.它的添加、 删除操作都是 O(1) (平均) 。

hash 特别适合用于存储对象。 相较于将对象的每个字段存成单个 string 类型。 将一个对象存储在 hash 类型中会占用更少的内存,并且可以更方便的存取整个对象。省内存的原因是新建一个 hash 对象时开始是用 zipmap(又称为 small hash)来存储的。这个 zipmap 其实并不是 hash table,但是 zipmap 相比正常的 hash 实现可以节省不少 hash 本身需要的一些元数据存储开销。尽管 zipmap 的添加,删除,查找都是 O(n),但是由于一般对象的 field 数量都不太多。所以使用 zipmap 也是很快的,也就是说添加删除平均还是 O(1)。如果 field 或者 value的大小超出一定限制后, Redis 会在内部自动将 zipmap 替换成正常的 hash 实现. 这个限制可以在配置文件中指定hash-max-zipmap-entries 64 #配置字段最多 64 个hash-max-zipmap-value 512 #配置 value 最大为 512 字节

HASH常见命令

  1. HSET

    HSET key field value

    将哈希表 key 中的域 field 的值设为 value 。

    如果 key 不存在,一个新的哈希表被创建并进行HSET 操作。

    如果域 field 已经存在于哈希表中,旧值将被覆盖。

    时间复杂度: O(1)

    返回值:

      如果 field 是哈希表中的一个新建域,并且值设置成功,返回 1 。

      如果哈希表中域 field 已经存在且旧值已被新值覆盖,返回 0 。

    127.0.0.1:6379[15]> HSET website google "www.g.cn"
    (integer) 1
    127.0.0.1:6379[15]>  HSET website google "www.google.com"
    (integer) 0
  2. HSETNX

    HSETNX key field value

    将哈希表 key 中的域 field 的值设置为 value ,当且仅当域 field 不存在。若域 field 已经存在,该操作无效。

    如果 key 不存在,一个新哈希表被创建并执行HSETNX 命令。

    时间复杂度: O(1)

    返回值:

      设置成功,返回 1 。

      如果给定域已经存在且没有操作被执行,返回 0 。

    127.0.0.1:6379[15]> HSETNX nosql key-value-store redis
    (integer) 1
    127.0.0.1:6379[15]>  HSETNX nosql key-value-store Memcached
    (integer) 0
    127.0.0.1:6379[15]> HGET nosql key-value-store
    "redis"
  3. HMSET

    HMSET key field value [field value …]

    同时将多个 field-value (域 -值) 对设置到哈希表 key 中。此命令会覆盖哈希表中已存在的域。

    如果 key 不存在,一个空哈希表被创建并执行HMSET 操作。

    时间复杂度: O(N),N 为 field-value 对的数量。

    返回值:

      如果命令执行成功,返回 OK 。

      当 key 不是哈希表 (hash) 类型时,返回一个错误。

    127.0.0.1:6379[15]> HMSET website google www.google.com yahoo www.yahoo.com
    OK
    127.0.0.1:6379[15]> HGET website google
    "www.google.com"
    127.0.0.1:6379[15]> HGET website yahoo
    "www.yahoo.com"
  4. HGET

    HGET key field

    返回哈希表 key 中给定域 field 的值。

    时间复杂度: O(1)

    返回值:

      给定域的值。

      当给定域不存在或是给定 key 不存在时,返回 nil 。

    127.0.0.1:6379[15]> HSET site redis redis.com
    (integer) 1
    127.0.0.1:6379[15]> HGET site redis
    "redis.com"
    127.0.0.1:6379[15]> HGET site mysql
    (nil)
  5. HMGET

    返回哈希表 key 中,一个或多个给定域的值。

    如果给定的域不存在于哈希表,那么返回一个 nil 值。

    因为不存在的 key 被当作一个空哈希表来处理,所以对一个不存在的 key 进行HMGET 操作将返回一个只 带有 nil 值的表。

    时间复杂度: O(N),N 为给定域的数量。

    返回值: 一个包含多个给定域的关联值的表,表值的排列顺序和给定域参数的请求顺序一样。

    127.0.0.1:6379[15]>  HMSET pet dog "doudou" cat "nounou"
    OK
    127.0.0.1:6379[15]>  HMGET pet dog cat fake_pet
    1) "doudou"
    2) "nounou"
    3) (nil)
  6. HEXISTS

    HEXISTS key field

    查看哈希表 key 中,给定域 field 是否存在。

    时间复杂度: O(1)

    返回值:

      如果哈希表含有给定域,返回 1 。

      如果哈希表不含有给定域,或 key 不存在,返回 0 。

    127.0.0.1:6379[15]> HEXISTS phone myphone
    (integer) 0
    127.0.0.1:6379[15]> HSET phone myphone nokia-1110
    (integer) 1
    127.0.0.1:6379[15]> HEXISTS phone myphone
    (integer) 1
  7. HDEL

    HDEL key field [field …]

    删除哈希表 key 中的一个或多个指定域,不存在的域将被忽略。

    时间复杂度: O(N),N 为要删除的域的数量。

    返回值: 被成功移除的域的数量,不包括被忽略的域。

    127.0.0.1:6379[15]> HMSET key f1 "v1" f2 "v2" f3 "v3" f4 "v4"
    OK
    127.0.0.1:6379[15]> HGETALL key
    1) "f1"
    2) "v1"
    3) "f2"
    4) "v2"
    5) "f3"
    6) "v3"
    7) "f4"
    8) "v4"
    127.0.0.1:6379[15]> HDEL key f1
    (integer) 1
    127.0.0.1:6379[15]> HDEL key not-field
    (integer) 0
    127.0.0.1:6379[15]> HDEL key f2 f3
    (integer) 2
    127.0.0.1:6379[15]> HDEL key f4 f1
    (integer) 1
  8. HKEYS

    HKEYS key

    返回哈希表 key 中的所有域。

    时间复杂度: O(N),N 为哈希表的大小。

    返回值:

      一个包含哈希表中所有域的表。

      当 key 不存在时,返回一个空表。

    127.0.0.1:6379[15]> HMSET website google www.google.com yahoo www.yahoo.com
    OK
    127.0.0.1:6379[15]> HKEYS website
    1) "google"
    2) "yahoo"
    127.0.0.1:6379[15]> EXISTS fake_key
    (integer) 0
    127.0.0.1:6379[15]> HKEYS fake_key
    (empty list or set)
  9. HVALS

    HVALS key

    返回哈希表 key 中所有域的值。

    时间复杂度: O(N),N 为哈希表的大小。

    返回值:

      一个包含哈希表中所有值的表。

      当 key 不存在时,返回一个空表。

    127.0.0.1:6379[15]> HMSET website google www.google.com yahoo www.yahoo.com
    OK
    127.0.0.1:6379[15]> HVALS website
    1) "www.google.com"
    2) "www.yahoo.com"
    127.0.0.1:6379[15]> EXISTS not_exists
    (integer) 0
    127.0.0.1:6379[15]> HVALS not_exists
    (empty list or set)
  10. HGETALL

    HGETALL key

    返回哈希表 key 中,所有的域和值。

    在返回值里,紧跟每个域名 (field name) 之后是域的值 (value),所以返回值的长度是哈希表大小的两倍。

    时间复杂度: O(N),N 为哈希表的大小。

    返回值:

      以列表形式返回哈希表的域和域的值。

      若 key 不存在,返回空列表。

    127.0.0.1:6379[15]> HSET people jack "Jack Sparrow"
    (integer) 1
    127.0.0.1:6379[15]> HSET people gump "Forrest Gump"
    (integer) 1
    127.0.0.1:6379[15]> HGETALL people
    1) "jack"
    2) "Jack Sparrow"
    3) "gump"
    4) "Forrest Gump"
  11. HINCRBY

    HINCRBY key field increment

    为哈希表 key 中的域 field 的值加上增量 increment 。

    增量也可以为负数,相当于对给定域进行减法操作。

    如果 key 不存在,一个新的哈希表被创建并执行HINCRBY 命令。

    如果域 field 不存在,那么在执行命令前,域的值被初始化为 0 。

    对一个储存字符串值的域 field 执行HINCRBY 命令将造成一个错误。

    本操作的值被限制在 64 位 (bit) 有符号数字表示之内。

    时间复杂度: O(1)

    返回值: 执行HINCRBY 命令之后,哈希表 key 中域 field 的值。

    127.0.0.1:6379[15]> HEXISTS counter page_view
    (integer) 0
    127.0.0.1:6379[15]>  HINCRBY counter page_view 200
    (integer) 200
    127.0.0.1:6379[15]> HGET counter page_view
    "200"
    127.0.0.1:6379[15]>  HINCRBY counter page_view -50
    (integer) 150
    127.0.0.1:6379[15]>  HGET counter page_view
    "150"
  12. HINCRBYFLOAT

    HINCRBYFLOAT key field increment

    为哈希表 key 中的域 field 加上浮点数增量 increment 。

    如果哈希表中没有域 field ,那么HINCRBYFLOAT 会先将域 field 的值设为 0 ,然后再执行加法操作。

    如果键 key 不存在,那么HINCRBYFLOAT 会先创建一个哈希表,再创建域 field ,最后再执行加法操作。

    当以下任意一个条件发生时,返回一个错误:

      域 field 的值不是字符串类型 (因为 redis 中的数字和浮点数都以字符串的形式保存,所以它们都属于字符串类型)

      域 field 当前的值或给定的增量 increment 不能解释 (parse) 为双精度浮点数 (double precision floating point number)

    返回值: 执行加法操作之后 field 域的值。

    127.0.0.1:6379[15]> HSET mykey field 10.50
    (integer) 0
    127.0.0.1:6379[15]> HINCRBYFLOAT mykey field 0.1
    "10.6"
    127.0.0.1:6379[15]> HSET mykey field 5.0e3
    (integer) 0
    127.0.0.1:6379[15]> HINCRBYFLOAT mykey field 2.0e2
    "5200"
    127.0.0.1:6379[15]> EXISTS price
    (integer) 0
    127.0.0.1:6379[15]> HINCRBYFLOAT price milk 3.5
    "3.5"
    127.0.0.1:6379[15]> HGETALL price
    1) "milk"
    2) "3.5"
  13. HLEN

    HLEN key

    返回哈希表 key 中域的数量。

    返回值:

      哈希表中域的数量。

      当 key 不存在时,返回 0 。

    127.0.0.1:6379[15]> HSET db redis redis.com
    (integer) 1
    127.0.0.1:6379[15]> HSET db mysql mysql.com
    (integer) 1
    127.0.0.1:6379[15]> HLEN db
    (integer) 2
    127.0.0.1:6379[15]> HSET db mongodb mongodb.org
    (integer) 1
    127.0.0.1:6379[15]> HLEN db
    (integer) 3
时间: 2024-10-01 06:03:52

Redis数据类型之HASH类型的相关文章

redis数据类型之-Hash

(1)Hash简介 Hash类型适合存储对象,字段值只能是字符串,不支持其他数据类型. (2)Hash常用命令 // 增加hash属性值 > hset user:100 name zm (integer) 1 > hset user:100 age 30 (integer) 1 > hset user:100 sex 1 (integer) 1 // 获取指定的某个属性的值 > hget user:100 sex "1" // 获取指定的多个属性的值 >

[redis数据结构]之 hash类型

在讲解语法知识之前,教你如何掌握各种hash的基本潜规则,在不同的语言中,有点称之为hash.有的是map,但不管这么样,hash你可以看作是key-value一组的集合.我先将java中map的概念擅自的加入到redis的hash中,让我们更加容易的理解hash的潜规则: 一.hash潜规则 1.映射模型 值集合映射,键集合映射,Entry集合映射(key-value,有得称之为item(python)). 2.一般的方法列表 添加.删除.更新.判断键是否存在.对应映射模型的key集合.val

小蚂蚁学习Redis笔记(4)——Redis数据类型之hashes类型

hashes类型 hash是一个string类型的field和value的映射表.它特别适合用于存储对象.相较于将对象的每个字段存成单个的string类型,将一个对象存储在hash类型中会占用更少的内存,并且可以更方便的存取整个对象. hashes常用命令 1.    hset    设置对象的字段和值 格式:    hset    user:001    name    "allen" 含义:为user:001这个对象,将它的name键设置一个值为allen. 注意:如果同样的对象,

Redis数据类型之SORTEDSET类型

Web程序猿博客:http://blog.csdn.net/thinkercode sorted set类型-特点 sorted set 是 set 的一个升级版本,它在 set 的基础上增加了一个顺序属性,这一属性在添加修改元素的时候可以指定,每次指定后,zset 会自动重新按新的值调整顺序.可以理解为有两列的 mysql 表,一列存 value,一列存顺序.操作中 key 理解为 zset 的名字. 和 set 一样 sorted set 也是 string 类型元素的集合,不同的是每个元素

redis string和hash类型操作

Redis 的数据类型 String类型及操作 String是最简单的类型,一个Key对应一个Value,sting类型是二进制安全的.Redis的string可以包含任何数据,比如jpg图片或者序列化的对象. 例子: set name gxj get name 输出:gxj Setnx:设置key对应的值为string类型的value,如果key 已经存在,则返回0,nx是not exist的意思. 例子: set name zjz 回车:则返回0,如果不存在,则会设置值 setex: 设置k

redis 数据类型和对象类型

1 数据类型 这些数据结构我们并不会用到,他是redis底层的数据结构. 我们能够用到的是对象 1.1 简单动态字符串 redis中的字符串使用的是 struct sdshdr { int len; //已用长度 int free; //未用长度 char buf[]; // buf 的大小为len+free+1 } 最后依然兼容c的字符串,最后一个字节使用'\0',因此最终的总长度为len+free+1 相比较c的字符串优点在于: o(1)内获得字符串长度 避免了缓冲区溢出 减少了修改字符串带

Redis数据类型之SET类型

Web程序猿博客:http://blog.csdn.net/thinkercode set类型-特点 set 是集合,和我们数学中的集合概念相似,对集合的操作有添加删除元素,有对多个集合求交并差等操作,操作中 key 理解为集合的名字. Redis 的 set 是 string 类型的无序集合.set 元素最大可以包含(2 的 32 次方)个元素. set 的是通过 hash table 实现的,所以添加.删除和查找的复杂度都是 O(1).hash table 会随着添加或者删除自动的调整大小.

Redis数据类型之LIST类型

Web程序猿博客:http://blog.csdn.net/thinkercode list类型-特点 list 是一个链表结构,主要功能是 push.pop.获取一个范围的所有值等等,操作中 key理解为链表的名字. Redis 的 list类型其实就是一个每个子元素都是 string 类型的双向链表.链表的最大长度是(2的 32 次方).我们可以通过 push,pop 操作从链表的头部或者尾部添加删除元素.这使得 list既可以用作栈,也可以用作队列. 有意思的是 list 的 pop 操作

小蚂蚁学习Redis笔记(5)——Redis数据类型之list类型

Redis之lists类型以及操作 list是一个链表结构,主要功能是push.pop,获取一个范围的所有值等等.操作中key理解为链表的名字.Redis的list类型其实就是一个每个子元素都是string类型的双向链表.可以通过push.pop操作从链表的头部或者尾部添加删除元素,这样list既可以作为栈,也可以作为队列. 栈和队列的特性    栈:先进后出:队列:先进先出. 1.    lpush    为链表的头部添加字符串元素 格式:    lpush    mylist1    "al