一:Redis 哈希(Hash)

  Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。

  Redis 中每个 hash 可以存储 232 - 1 键值对(40多亿).

  redis中Hash在内存中的存储格式如下图

--------------------------------------------------------------------

二:hash常用命令

  1)hset(name, key, value)         name对应的hash中设置一个键值对(不存在,则创建;否则,修改)

  2)hmset(name, mapping)        在name对应的hash中批量设置键值对

  3)hget(name,key)   在name对应的hash中获取根据key获取value

  4)hmget(name, keys, *args)  在name对应的hash中获取多个key的值

  5)hgetall(name)  获取name对应hash的所有键值

  6)hlen(name) 获取name对应的hash中键值对的个数

  7)hkeys(name) 获取name对应的hash中所有的key的值

  8)hvals(name) 获取name对应的hash中所有的value的值

  9)hexists(name, key) 检查name对应的hash是否存在当前传入的key

  10)hdel(name,*keys) 将name对应的hash中指定key的键值对删除

  11)hincrby(name, key, amount=1)  自增name对应的hash中的指定key的值,不存在则创建key=amount

  12)hincrbyfloat(name, key, amount=1.0) 自增name对应的hash中的指定key的值,不存在则创建key=amount

  13)hscan(name, cursor=0, match=None, count=None) 迭代哈希表中的键值对

  14)hscan_iter(name, match=None, count=None) 利用yield封装hscan创建生成器,实现分批去redis中获取数据

三:示例

[BEGIN] 2017/7/29 21:29:50
127.0.0.1:6379> HSET n1 k1 "shi" 生成一个hash 一个键值对
(integer) 1
127.0.0.1:6379> HSET n2 k2 "san" k3 "jun" 生成hash 批量键值对
(integer) 2
127.0.0.1:6379> HGET n1 k1 hash中获取根据key获取value
"shi"
127.0.0.1:6379> HMGET n2 k2 k3 对应的hash中获取多个key的值
1) "san"
2) "jun"
127.0.0.1:6379> HGETALL n2 hash的所有键值
1) "k2"
2) "san"
3) "k3"
4) "jun"
127.0.0.1:6379> HLEN n2 对应的hash中键值对的个数
(integer) 2
127.0.0.1:6379> HKEYS n2 对应的hash中所有的key的值
1) "k2"
2) "k3"
127.0.0.1:6379> HVALS n2 对应的hash中所有的value的值
1) "san"
2) "jun"
127.0.0.1:6379> HEXISTS n2 k2 对应的hash是否存在当前传入的key
(integer) 1
127.0.0.1:6379> HEXISTS n2 k1
(integer) 0
127.0.0.1:6379> HDEL n2 k2 对应的hash中指定key的键值对删除
(integer) 1
127.0.0.1:6379> HGET n2 k2
(nil)
127.0.0.1:6379> HINCRBY n2 k3 2 自增name对应的hash中的指定key的值,不存在则创建key=amount
(error) ERR hash value is not an integer
127.0.0.1:6379> HSET n2 k4 1
(integer) 1
127.0.0.1:6379> HINCRBY n2 k4 1
(integer) 2
127.0.0.1:6379> HINCRBYFLOAT n2 k4 2.3
"4.3"
127.0.0.1:6379> HSCAN n2 0 match j*
1) ""
2) (empty list or set)
127.0.0.1:6379> HSCAN n2 0 match k* 迭代哈希表中的键值对
1) ""
2) 1) "k3"
2) "jun"
3) "k4"
4) "4.3"
127.0.0.1:6379> HSCAN_iter n2 match k*
(error) ERR unknown command 'HSCAN_iter' [END] 2017/7/29 21:43:48

缓存数据库-redis数据类型和操作(hash)的更多相关文章

  1. 缓存数据库-redis数据类型和操作(list)

    转: 狼来的日子里! 奋发博取 缓存数据库-redis数据类型和操作(list) 一:Redis 列表(List) Redis列表是简单的字符串列表,按照插入顺序排序.你可以添加一个元素导列表的头部( ...

  2. 缓存数据库-redis数据类型和操作(string)

    Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合) 一:String(字符串) string是redis ...

  3. 缓存数据库-redis数据类型和操作(sorted set)

    一:Redis 有序集合(sorted set) Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员. 不同的是每个元素都会关联一个double类型的分数.redis正是 ...

  4. 缓存数据库-redis数据类型和操作(set)

    一:Redis 集合(Set) Redis的Set是string类型的无序集合.集合成员是唯一的,这就意味着集合中不能出现重复的数据. Redis 中 集合是通过哈希表实现的,所以添加,删除,查找的复 ...

  5. 缓存数据库redis

    什么是Redis? Redis是一个TCP服务器,支持请求/响应协议. 在Redis中,请求通过以下步骤完成: 客户端向服务器发送查询,并从套接字读取,通常以阻塞的方式,用于服务器响应. 服务器处理命 ...

  6. Redis数据类型及其操作

    redis数据类型即操作 1. 字符串 set 设置字符串 格式: set key value 例子: set name kainhuck get 获取字符串的值 格式: get key 例子: ge ...

  7. 缓存数据库-redis介绍

    一:Redis 简介 Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. Redis 与其他 key - value 缓存产品有以下三个特点: Redis支持数据的 ...

  8. Redis数据类型和操作

    <"Java技术员"成长手册>,包含框架.存储.搜索.优化.分布式等必备知识,都收集在GitHub JavaEgg ,N线互联网开发必备技能兵器谱,欢迎指导 Redis ...

  9. 三个缓存数据库Redis、Memcache、MongoDB

    >>Memcached Memcached的优点:Memcached可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS(取决于key.value的字节大小以及服务器硬件性能,日常环境 ...

随机推荐

  1. BZOJ 2527 Meteors | 整体二分

    BZOJ 2527 Meteors 题意 一个圆环上有m个位置,编号为1~m,分别属于n个国家. 有k个时刻,每个时刻都会给圆环上的一个区间中每个位置的值加上一个数. 每个国家有一个目标,问对于每个国 ...

  2. #define后面只带有一个标识符

    经常看到有#define后只有一个标识符的语句,这样是做宏开关用 宏定义编译前会被编译器进行替换,只有一个标识符的情况,如果在代码里使用了这个标识符,会被替换为空,也就是相当于没加. 用来做编译开关的 ...

  3. loj2541【PKUWC2018】猎人杀

    题解 题目中的选择条件等价于正常选择所有猎人,而如果选到已经出局的猎人就继续选: 这两种选法是一样的因为(设$W=\sum_{i=1}^{n}w_{i}$ , $X$为已经出局的猎人的$w$之和): ...

  4. 使用spring cache和ehcache

    一.spring cache Spring Cache是作用在方法上的,其核心思想是这样的:当我们在调用一个缓存方法时会把该方法参数和返回结果作为一个键值对存放在缓存中,等到下次利用同样的参数来调用该 ...

  5. pickle 在python2 to python3 编码出现错误

    pickle.load(file) UnicodeDecodeError: 'ascii' codec can't decode byte 0xf5 in position 2: ordinal no ...

  6. Jenkins和Gitblit集成实现提交后自动构建

    Gitblit是一个纯Java基于git的解决方案.它属于Apache Allura等伪造软件之一,它将票务系统与web ui结合在一起.我经历了一个设置过程,我想我可以帮助新用户避免痛点. 使用场景 ...

  7. extract_by_one 根据二维数组中某字段来提取数组信息,查看有无重复信息

    public function tt(){ $param = array( array ( 'hykno' => '2222222-CB', 'tcdk_fid' => '458B6D70 ...

  8. C++中基于成员函数是否是const重载成员函数

    C++pimer中文版第四版 378页 基于const的重载 如果我们要在一个类的成员函数中定义两个函数签名完全一样的成员函数,比如display,那么可以基于是否是const成员函数来重载.比如: ...

  9. Integer两种转int方法比较

    方法一: Integer.parseInt(); 返回的是一个 int 的值. 方法二: new Integer.valueof(); 返回的是 Integer 的对象. new Integer.va ...

  10. windows配置Python多版本共存

    windows配置Python多版本共存 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 最近Python开发蛮火的,三年前我的一个运维朋友就告诉我说Python语言将来会很火,当时 ...