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)

小贝_redis hash类型学习的更多相关文章

  1. 小贝_redis list类型学习

    redis  list类型 一.查看list类型的命令 二.list命令具体解释 一.查看list类型的命令 1.在终端数据 help @list 127.0.0.1:6379>help @li ...

  2. 小贝_php+redis类型组合使用

    php_redis类型组合使用 一.类型组合说明 经过前面的文章介绍.已经知道redis有字符串.集合.列表.hash等内置数据类型. 这里以,无序集合为例,进行说明. 集合 set1的简图 1.从简 ...

  3. 小贝_redis高级应用-公布与订阅

    redis高级应用-公布与订阅 一.公布与订阅(pub/sub)功能 二.公布与订阅(pub/sub)机制 三.redis公布与订阅(pub/sub)的实现 一.公布与订阅(pub/sub)功能 Pu ...

  4. 小贝_redis 高级应用-事务

    redis高级应用-事务 一.redis的事务 二.redis实现事务 三.redis事务问题 一.redis的事务 事务提供了一种"将多个命令打包,然后一次性.按顺序地运行"的机 ...

  5. 小贝_redis高级应用-安全性

    redis高级应用-安全性 一.为什么redis须要安全性 二.设置redis验证password 三.验证   一.为什么redis须要安全性 1.redis作为数据的存储介质.假设无法保证redi ...

  6. 小贝_redis web管理界面工具安装

    RedisWEB管理界面工具安装 一.概述 二.文件下载 三.安装过程 一.概述 1.因为redis是基于C/S的方式开发.也就是说,仅仅要满足于redis的client通信要求的,都能够作为redi ...

  7. Redis学习第三课:Redis Hash类型及操作

    Redis hash是一个string类型的field和value的映射表.它的添加.删除操作都是O(1)(平均).hash特别适用于存储对象.相较于对象的每个字段存在单个string类型.将一个对象 ...

  8. Redis中Value使用hash类型的效率是普通String的两倍

    什么Redis? 点击这里 最近要开发的一个项目是分布式缓存组件,解决参数缓存高效获取的问题.参数达到了500万级别,刚刚开始了解Redis.做设计的时候考虑到Value使用哪种类型的问题? 主要面临 ...

  9. 【redis】02string类型和hash类型

    Redis的数据类型   Redis主要分为五个数据类型,一个是string,最简单的一个数据类型,hash,list, 还有set集合,还有zset有序集合,这是咱们redis的五种基础类型, 接下 ...

随机推荐

  1. 【bzoj4319】cerc2008 Suffix reconstruction 贪心

    题目描述 话说练习后缀数组时,小C 刷遍 poj 后缀数组题, 各类字符串题闻之丧胆.就在准备对敌方武将发出连环杀时,对方一记无中生有,又一招顺手牵羊,小C 程序中的原字符数组就被牵走了.幸运的是,小 ...

  2. 用jQuery实现搜索框的过滤效果

    遇到的问题: 1.动态添加了某些元素,在动态添加的某个元素上绑定事件失效 原因:因为需要绑定的元素的直接父元素也是动态添加的解决:向上为上一级父元素绑定事件 $(".check-box&qu ...

  3. BZOJ1226 [SDOI2009]学校食堂Dining 【状压dp】

    题目 小F 的学校在城市的一个偏僻角落,所有学生都只好在学校吃饭.学校有一个食堂,虽然简陋,但食堂大厨总能做出让同学们满意的菜肴.当然,不同的人口味也不一定相同,但每个人的口味都可以用一个非负整数表示 ...

  4. linux下定时任务设置

    原文http://www.blogjava.net/freeman1984/archive/2010/09/23/332715.html 觉这篇文章写的挺全的,把它拿过来存在博客里,方便以后查询. 为 ...

  5. 主机ping不通虚拟机,但是虚拟机能ping通主机

    一.虚拟机网络连接方式选择Nat 二. 关闭Linux防火墙命令:service iptables stop / service firewalld stop 查看Linux防火墙状态命令:servi ...

  6. 马士兵hadoop第二课:hdfs集群集中管理和hadoop文件操作(转)

    马士兵hadoop第一课:虚拟机搭建和安装hadoop及启动 马士兵hadoop第二课:hdfs集群集中管理和hadoop文件操作 马士兵hadoop第三课:java开发hdfs 马士兵hadoop第 ...

  7. poj 1418 Viva Confetti

    Viva Confetti Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 1025   Accepted: 422 Desc ...

  8. 百度图表echars插件使用案例

    <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding= ...

  9. Intent显示启动与隐式启动

    Android的Acitivity启动大致有两种方式:显式启动与隐式启动.下面分别介绍: 1.显示启动: 清单文件注册Activity <activity android:name=" ...

  10. 《Vim实用技巧》第2版读书笔记

    学习前的建议: 一.如果你需要一个功能强大的文本编辑器,速度飞快.使用方便.代码补全.编程强大.定制性强,Vim就是你需要的: 二.学习入门曲线陡峭,但是使用后期异常简单,效率超高: 三.号称可以跟上 ...