zoukankan      html  css  js  c++  java
  • 小贝_redis hash类型学习

    Redis  Hash类型

    一、查看hash类型的命令

    二、操作hash命令具体解释

     

    一、查看hash类型的命令

    1、输入 help@hash

    127.0.0.1:6379>help @hash

      HDEL key field [field ...]

      summary: Delete one or more hash fields

      since: 2.0.0

     

      HEXISTS key field

      summary: Determine if a hash field exists

      since: 2.0.0

     

      HGET key field

      summary: Get the value of a hash field

      since: 2.0.0

     

      HGETALL key

      summary: Get all the fields and values in ahash

      since: 2.0.0

     

      HINCRBY key field increment

      summary: Increment the integer value of ahash field by the given number

      since: 2.0.0

    备注: 因为篇幅太大。因此省略一些。

     

     

    二、操作hash命令具体解释

    1、hset

    hset key field value

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

    假设key不存在。一个新的哈希表被创建并进行hset操作。

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

    时间复杂度:

    O(1)

    返回值:

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

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

    127.0.0.1:6379> hset website google "www.g.cn"   # 一个新域

    (integer) 1

    127.0.0.1:6379> 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>hsetnx nosql key-value-store redis

    (integer) 1

    127.0.0.1:6379> hsetnx nosql key-value-store redis  # 操作无效,域key-value-store已存在

    (integer) 0

     

    3、hmset

    hmset key field value [fieldvalue ...]

    同一时候将多个field - value(域-值)对设置到哈希表key中。

    此命令会覆盖哈希表中已存在的域。

    假设key不存在,一个空哈希表被创建并运行hmset操作。

    时间复杂度:

    O(N)。N为field - value对的数量。

    返回值:

    假设命令运行成功,返回OK。

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

    # 情况1: 哈希表

    127.0.0.1:6379> hmset website google www.google.com yahoowww.yahoo.com

    OK

    127.0.0.1:6379> hget website google

    "www.google.com"

    127.0.0.1:6379> hget website yahoo

    "www.yahoo.com"

    # 情况2:类型错误时

    127.0.0.1:6379> set G 10  #出错情况

    OK

    127.0.0.1:6379> hmset G name huangz age 20

    (error) ERR Operation against a key holding the wrongkind of value

     

    4、hget

    hget key field

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

    时间复杂度:

    O(1)

    返回值:

    给定域的值。

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

    127.0.0.1:6379> hset huangz blog huangz.iteye.com

    (integer) 1

     

    127.0.0.1:6379> hget huangz blog

    "huangz.iteye.com"

     

    5、hmget

    hget  key field [field ...]

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

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

    由于不存在的key被当作一个空哈希表来处理。所以对一个不存在的key进行hmget操作将返回一个仅仅带有nil值的表。

    时间复杂度:

    O(N)。N为给定域的数量。

    返回值:

    一个包括多个给定域的关联值的表。表值的排列顺序和给定域參数的请求顺序一样。

    127.0.0.1:6379> hmset pet dog "doudou" cat"nounou"  # 一次保存多个值

    OK

    127.0.0.1:6379> hmget pet dog cat fake_pet  # 返回值的顺序和传入參数的顺序一样。

    1) "doudou"

    2) "nounou"

    3) (nil)  # 不存在的域返回nil值

    6、hgetall

    hgetall key

    返回哈希表key中。全部的域和值。

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

    时间复杂度:

    O(N)。N为哈希表的大小。

    返回值:

    以列表形式返回哈希表的域和域的值。若key不存在,返回空列表。

    127.0.0.1:6379>hset hash_name jack"Jack Sparrow"

    (integer) 1

    127.0.0.1:6379> hset hash_name gump"Forrest Gump"

    (integer) 1

    127.0.0.1:6379> hgetall hash_name

    1) "jack"          # 域

    2) "Jack Sparrow"  # 值

    3) "gump"

    4) "Forrest Gump"

    7、hdel

    hdel key field [field ...]

    删除哈希表key中的一个或多个指定域。

    不存在的域将被忽略。

    时间复杂度:

    O(N)。N为要删除的域的数量。

    返回值:

    若域存在且被成功删除。返回1。

    若key不存在或域不存在,返回0。

    注解

    在Redis2.2及2.2下面的版本号里,hdel每次仅仅能删除单个域,假设你须要在一个原子时间内删除多个域,请将命令包括在MULT/EXEC块内。

    127.0.0.1:6379> hset hash_name jack "Jack Sparrow"

    (integer) 1

    127.0.0.1:6379> hget hash_name jack

    "Jack Sparrow"

    127.0.0.1:6379> hdel hash_name jack

    (integer) 1

    127.0.0.1:6379> hget hash_name jack

    (nil)

    8、hlen

    hlen key

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

    时间复杂度:

    O(1)

    返回值:

    哈希表中域的数量。

    当key不存在时,返回0。

    127.0.0.1:6379> hset hash_name jack"Jack Sparrow"

    (integer) 1

    127.0.0.1:6379> hset hash_name gump"Forrest Gump"

    (integer) 1

    127.0.0.1:6379> hlen hash_name

    (integer) 2

    9、hexists

    hexists key field

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

    时间复杂度:

    O(1)

    返回值:

    假设哈希表含有给定域。返回1。

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

    127.0.0.1:6379> hexists phone myphone

    (integer) 0

     

    127.0.0.1:6379> hset phone myphone nokia-1110

    (integer) 1

     

    127.0.0.1:6379> hexists phone myphone

    (integer) 1

    10、hincrby

    hincrby key field increment

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

    假设key不存在,一个新的哈希表被创建并运行hincrby命令。

    假设域field不存在,或域已有的字符串值不能表示为数字。那么在运行命令前,域的值被设置为0。

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

    时间复杂度:

    O(1)

    返回值:

    运行hincrby命令之后,哈希表key中域field的值。

    127.0.0.1:6379> hexists hash_count page_views

    (integer) 0

     

    127.0.0.1:6379> hincrby hash_count page_views 200

    (integer) 200

     

    127.0.0.1:6379> hincrby hash_count page_views 10

    (integer) 210

    11、hkeys

    hkeys  key

    返回哈希表key中的全部域。

    时间复杂度:

    O(N),N为哈希表的大小。

    返回值:

    一个包括哈希表中全部域的表。

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

    # 情况1:哈希表非空

    127.0.0.1:6379> hmset website google www.google.com yahoowww.yahoo.com

    OK

    127.0.0.1:6379> hkeys website

    1) "google"

    2) "yahoo"

    # 情况2:空哈希表/key不存在

    127.0.0.1:6379>exists fake_key

    (integer) 0

    127.0.0.1:6379> hkeys fake_key

    (empty list or set)

    12、hvals

    hvals  key

    返回哈希表key中的全部值。

    时间复杂度:

    O(N),N为哈希表的大小。

    返回值:

    一个包括哈希表中全部值的表。

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

    # 情况1:非空哈希表

    127.0.0.1:6379> hmset website google www.google.com yahoowww.yahoo.com

    OK

     

    127.0.0.1:6379> hvals website

    1) "www.google.com"

    2) "www.yahoo.com"

    # 情况2:空哈希表/不存在的key

    127.0.0.1:6379> exists not_exists

    (integer) 0

    127.0.0.1:6379> hvals not_exists

    (empty list or set)

     

  • 相关阅读:
    cookie,请求报文,
    ser,ver
    关于 通知的 死循环,
    这读取的好蛋疼,为什么一写 一读就有问题了,不一致了,
    缓存小姐 挡拆,网络请求 不同步 惹的祸,
    viewdidload ,viewwillappear,
    提示输入 用户名 ,密码,--》转
    前端面试
    npm与cnpm
    vue与node和npm关系
  • 原文地址:https://www.cnblogs.com/jhcelue/p/7219216.html
Copyright © 2011-2022 走看看