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)

最新文章

  1. xcode8+iOS10问题
  2. [Tool] PLSQL使用技巧
  3. Codeforces Round #352 (Div. 2) C. Recycling Bottles 暴力+贪心
  4. px,dp,sp单位转换工具类
  5. 网上图书商城项目学习笔记-036工具类之CommonUtils及日期转换器
  6. ACM2026
  7. 如何使得VIM显示行号
  8. jquerymobile知识点:动态ListView
  9. LA 4329(树状数组)
  10. linux之普通用户与root用户之间切换
  11. Hibernate 关系映射方式(1)
  12. ubuntu 新手入门第一天
  13. JQuery官方学习资料(译):CSS
  14. UnzipUtil
  15. day10 参数args kwargs 作用域
  16. OS模块学习
  17. idea 修改设置 检测方式为 es6
  18. 简单对比 Libevent、libev、libuv
  19. 解决java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone
  20. JEECG(一) 如何配置自己的业务包

热门文章

  1. 设计模式(二十二)模板方法模式 Template
  2. 【Luogu】P3787冰精冻西瓜(线段树)
  3. 洛谷P4363 [九省联考2018]一双木棋chess 【状压dp】
  4. 解决vue项目route使用history模式,tomcat部署刷新url 404问题
  5. VMware 11 安装Mac 10.9
  6. JAVA Apache POI 之sax 解析10万级大数量数据
  7. SpringBoot之ApplicationContextInitializer的理解和使用
  8. gridview中的相关事件操作
  9. 快充 IC BQ25896 如何判斷 手機插著 adapter 充電器時,adapter Iout 大於限制,adapter Vout 小於 限制,導致 battery 不但沒充電且還需放電。
  10. 通过jQuery Ajax提交表单数据时同时上传附件