Redis数据类型之散列(hash)

1. 什么是散列

散列类似于一个字典,是一个<K, V>对的集合,不过这个key和value都只能是字符串类型的,不能嵌套,可以看做Java中的Map<String, String>。

2. 基本操作

赋值

散列操作不区分插入和更新,当设置一个field的时候如果不存在的话表示新增,如果已经存在的话则表示更新,之前的值会被覆盖掉。当设置值的时候如果field在之前不存在的话则返回1,视为新增,如果field已经存在的话,返回0,视为更新。

hset <key> <field> <value>

第一次赋值的时候因为k1不存在,是新增field操作,返回值是1,第二次k1已经存在了,是更新操作,返回值是0.

使用hmset一次赋多个值:

hmset <key> <field> <value> [<field> <value> …]

使用hsetnx只有当指定的field不存在时才赋值,这个是为了避免覆盖掉已有的值:

hsetnx <key> <field> <value>

返回值表示是否赋值成功,返回1表示这个field之前并不存在,此次赋值成功,返回0表示指定的field之前就已经存在,此次赋值失败。

取值

hget一次取一个值,hmget一次取出多个值:

hget <key> <field>
hmget <key> <field> [<field> …]

使用hgetall一次取出全部的field:

hgetall <key>

判断field是否已存在

hexists用于判断在指定的hash表中某个field是否已存在:

hexists <key> <field>

返回值是1或0,返回1表示指定的field已经存在,返回0表示不存在。

获取hash表中的field个数

使用hlen获取指定的hash表中field的个数:

hlen <key>

field自增

使用hincrby对某个整数类型的field一次自增某个整数量:

hincrby <key> <field> <increment>

获取field及value

用于获取hash表中的field集合和value集合:

hkeys <key>
hvals <key>

返回值是一个列表:

删除

要删除hash表中的某个field,使用hdel:

hdel <key> <field> [<field> …]

hdel的返回值是成功删除的field的个数。

可以一次删除多个filed:

返回值是2表示成功删除了两个field。

要删除hash表本身使用del命令:

del是用于删除key即hash表本身的,hdel是用于删除hash表中的field的。

参考资料:

1. 《redis入门指南》 第二版

时间: 2024-10-07 03:55:00

Redis数据类型之散列(hash)的相关文章

非对称算法,散列(Hash)以及证书的那些事

转载请注明出处 http://blog.csdn.net/pony_maggie/article/details/35389657 作者:小马 这几个概念在金融电子支付领域用得比较多,我忽然觉得把它们串起来一起讲,层层引入,可能更好理解一些.希望能以最简单朴实的方式讲明白他们之间的关系. 一非对称算法 关于非对称算法,你只要知道下面这些就行了,密钥是一对,一个叫公钥,一个叫私钥,前者公开,后者保密.假设你有一对公私钥,给你一串数据,你可以用私钥加密,然后把密文和公钥都放出去,别人可以用这个公钥解

Redis数据操作--散列键

| 一个散列由多个域 值对(field-value pair)组成,散列的域和值都可以     是文字,整数,浮点数或者二进制数据. # 同一个散列中每个域必须是独一无二的,而不同域的值可以是重复的. # 操作:设置域值对,获取域的值,检查域是否存在 | 基本操作 -- 关联域值对     hset key field value     # 在散列键key中关联给定的域值对field和value     # 如果域field之前没有关联值,那么命令返回1:     # 如果域field已经有关

散列(hash)

散列(hash)是常用的算法思想之一,在很多程序中都会有意无意地使用到. 先来看一个简单的问题:给出N个正整数,再给出M个正整数,问这M个数中每个数分别是否在N个数中出现过. 例如N=5,M=3,N个正整数{8,3,7,6,2},欲查询的M个正整数为{7,4,2},于是后者只有7和2在N个正整数中出现过, 而4是没有出现过的. 对于这个问题,最直观的思路是:对每个欲查询的正整数x,遍历所有的N个数,看是否有一个数与x相等.这种 做法的时间复杂度为O(MN),当N和M都很大时,时间复杂度显然太大!

7、python基本数据类型之散列类型

前言:python的基本数据类型可以分为三类:数值类型.序列类型.散列类型,本文主要介绍散列类型. 一.散列类型 内部元素无序,不能通过下标取值 1)字典(dict):用 {} 花括号表示,每一个元素包含键(key)和值(value),key是一般是唯一的,如果重复最后的一个键值对   会替换前面的,value不需要唯一. 2)集合(set):用 {} 花括号表示,存放一个个元素,可以是任意类型,但元素不允许重复. 注意: d = {} 定义的是一个空字典 s = set() 定义的是一个空集合

Redis研究(四)—散列类型

散列类型(hash)的键值也是一种字典结构,其存储了字段(field)和字段值的映射,但字段值只能是字符串,不支持其他数据类型. 散列类型不能嵌套其他的数据类型.一个散列类型键可以包含至多2^32-1个字段. 一.介绍 散列类型适合存储对象:使用对象类别和ID构成键名,使用字段表示对象的属性,而字段值则存储属性值. 如果要关系数据中存储汽车对象: 数据是以二维表的形式存储的,这就要求所有的记录都有同样的属性,无法单独为某条记录增减属性.如果想要为ID为1的汽车增加生产日期属性,就需要把数据表更改

Redis常用命令(一) 字符串键、散列键

redis是key-value的数据结构,每条数据都是一个键值对 键的类型是字符串,因为默认是字符串所以都不用加引号 注意:键不能重复 值的类型分为五种: 字符串string 散列hash 列表list 集合set 有序集合zset string字符串键 set key value  # 设置的键不存在则为添加,如果设置的键已经存在则修改 set name daiby set key value [NX|XX]  # NX: 如果key不存在则成功,反之失败(不覆盖旧值)! XX: 如果key存

《数据库系统概念》14-静态散列

顺序文件组织的缺点之一是必须通过访问索引或使用二分法搜索来定位数据,这需要较多的I/O操作.基于散列技术的文件组织方式则不需要访问索引结构,散列也提供了一种组织索引的方式.在散列(hash)技术中,用桶(bucket)来表示能存储一条或多条记录的存储单元.如果K代表所有搜索码的集合,B代表所有bucket的集合,则散列函数h表示一个从K到B的映射函数.插入搜索码为Ki的记录时,通过散列函数计算h(Ki)得出bucket的地址,如果这个bucket还有空间,就将数据插入.查询Ki时,也是先通过h(

Redis散列类型

散列类型(hash)的键值也是一种字典结构,其存储了字段(field)和字段值的映射,但字段值只能是字符串,不支持其他数据类型,换句话说,散列类型不能嵌套其他的数据类型.一个散列类型的键可以包含至多2^32-1个字段.除了散列类型,Redis的其他数据类型同样不支持数据类型嵌套.比如集合类型的每个元素都只能是字符串,不能是另一个集合或散列表等.散列类型适合存储对象:使用对象类别和对象ID构成键名,使用字段表示对象的属性,而字段值则存储属性值.例如要存储ID为2的汽车对象,可以分别使用名为colo

HashMap实现 Hash优化与高效散列

OverView Hash table based implementation of the Map interface. This implementation provides all of the optional map operations, and permits null values and the null key. (The HashMap class is roughly equivalent to Hashtable, except that it is unsynch