小贝_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)
小贝_redis hash类型学习的更多相关文章
- 小贝_redis list类型学习
redis list类型 一.查看list类型的命令 二.list命令具体解释 一.查看list类型的命令 1.在终端数据 help @list 127.0.0.1:6379>help @li ...
- 小贝_php+redis类型组合使用
php_redis类型组合使用 一.类型组合说明 经过前面的文章介绍.已经知道redis有字符串.集合.列表.hash等内置数据类型. 这里以,无序集合为例,进行说明. 集合 set1的简图 1.从简 ...
- 小贝_redis高级应用-公布与订阅
redis高级应用-公布与订阅 一.公布与订阅(pub/sub)功能 二.公布与订阅(pub/sub)机制 三.redis公布与订阅(pub/sub)的实现 一.公布与订阅(pub/sub)功能 Pu ...
- 小贝_redis 高级应用-事务
redis高级应用-事务 一.redis的事务 二.redis实现事务 三.redis事务问题 一.redis的事务 事务提供了一种"将多个命令打包,然后一次性.按顺序地运行"的机 ...
- 小贝_redis高级应用-安全性
redis高级应用-安全性 一.为什么redis须要安全性 二.设置redis验证password 三.验证 一.为什么redis须要安全性 1.redis作为数据的存储介质.假设无法保证redi ...
- 小贝_redis web管理界面工具安装
RedisWEB管理界面工具安装 一.概述 二.文件下载 三.安装过程 一.概述 1.因为redis是基于C/S的方式开发.也就是说,仅仅要满足于redis的client通信要求的,都能够作为redi ...
- Redis学习第三课:Redis Hash类型及操作
Redis hash是一个string类型的field和value的映射表.它的添加.删除操作都是O(1)(平均).hash特别适用于存储对象.相较于对象的每个字段存在单个string类型.将一个对象 ...
- Redis中Value使用hash类型的效率是普通String的两倍
什么Redis? 点击这里 最近要开发的一个项目是分布式缓存组件,解决参数缓存高效获取的问题.参数达到了500万级别,刚刚开始了解Redis.做设计的时候考虑到Value使用哪种类型的问题? 主要面临 ...
- 【redis】02string类型和hash类型
Redis的数据类型 Redis主要分为五个数据类型,一个是string,最简单的一个数据类型,hash,list, 还有set集合,还有zset有序集合,这是咱们redis的五种基础类型, 接下 ...
随机推荐
- 一步一步,完成sparkMLlib对日志文件的处理(1)
https://blog.csdn.net/u012834750/article/details/81014997 初学第一天,当然是完成helloWorld啦,有点艰难,2个小时,在idea, ...
- 刷题总结——做运动(NOIP模拟)
题目: 给定一个无向图,节点数n<=50000,m<=1000000,每条边有两个值t和c,边的长度为t*c···现在要求再t尽量小的情况下,求两节点st的最短距离 题解: 第一次做的时候 ...
- 面向对象oop思想
OOP核心思想:封装,继承,多态. 理解: 对象是由数据和容许的操作组成的封装体,与客观实体有直接对应关系,一个对象类定义了具有相似性质的一组对象.而每继承性是对具有层次关系的类的属性和操作进行共享的 ...
- 不吹不黑,关于 Java 类加载器的这一点,市面上没有任何一本图书讲到
类加载器第7弹: 实战分析Tomcat的类加载器结构(使用Eclipse MAT验证) 还是Tomcat,关于类加载器的趣味实验 了不得,我可能发现了Jar 包冲突的秘密 重写类加载器,实现简单的热替 ...
- 【NOIP2017】逛公园(最短路图,拓扑排序,计数DP)
题意: 策策同学特别喜欢逛公园. 公园可以看成一张 N 个点 M 条边构成的有向图,且没有自环和重边.其中 1 号点是公园的入口, N 号点是公园的出口,每条边有一个非负权值,代表策策经过这条边所要花 ...
- 标准C程序设计七---33
Linux应用 编程深入 语言编程 标准C程序设计七---经典C11程序设计 以下内容为阅读: <标准C程序设计>(第7版) 作者 ...
- LeetCode OJ--Gray Code **
http://oj.leetcode.com/problems/gray-code/ 求格雷码的表示,主要应用递归. 递归生成码表 这种方法基于格雷码是反射码的事实,利用递归的如下规则来构造: 1位格 ...
- 利用adb截屏
一 第一种方式 二 第二种方式
- Elasticsearch分词导致的查找错误
这周在做视频搜索的过程中遇到一个问题,就是用下面的查询表达式去Elasticsearch检索,检索不到想要的结果.查询语句如下: 而查询的字段的值为: "mergeVideoName&quo ...
- @RequestParam,@PathVariable,@ResponseBody,@RequestBody,@ModelAttribute学习
1.@RequestParam使用于参数上,用于将请求参数映射到指定参数变量上 例如: @RequestMapping(value="/hello",method=RequestM ...