Hash操作

Hash操作,redis中Hash在内存中的存储格式如下图:

hset(name, key, value)

1
2
3
4
5
6
7
8
9
# name对应的hash中设置一个键值对(不存在,则创建;否则,修改)
# 参数:
    # name,redis的name
    # key,name对应的hash中的key
    # value,name对应的hash中的value
# 注:
    # hsetnx(name, key, value),当name对应的hash中不存在当前key时则创建(相当于添加)

hmset(name, mapping)

1
2
3
4
5
6
7
8
# 在name对应的hash中批量设置键值对
# 参数:
    # name,redis的name
    # mapping,字典,如:{'k1':'v1', 'k2': 'v2'}
# 如:
    # r.hmset('xx', {'k1':'v1', 'k2': 'v2'})

hget(name,key)

1
# 在name对应的hash中获取根据key获取value

hmget(name, keys, *args)

1
2
3
4
5
6
7
8
9
10
11
# 在name对应的hash中获取多个key的值
# 参数:
    # name,reids对应的name
    # keys,要获取key集合,如:['k1', 'k2', 'k3']
    # *args,要获取的key,如:k1,k2,k3
# 如:
    # r.mget('xx', ['k1', 'k2'])
    # 或
    # print r.hmget('xx', 'k1', 'k2')

hgetall(name)

1
获取name对应hash的所有键值

hlen(name)

1
# 获取name对应的hash中键值对的个数

hkeys(name)

1
# 获取name对应的hash中所有的key的值

hvals(name)

1
# 获取name对应的hash中所有的value的值

hexists(name, key)

1
# 检查name对应的hash是否存在当前传入的key

hdel(name,*keys)

1
# 将name对应的hash中指定key的键值对删除

hincrby(name, key, amount=1)

1
2
3
4
5
# 自增name对应的hash中的指定key的值,不存在则创建key=amount
# 参数:
    # name,redis中的name
    # key, hash对应的key
    # amount,自增数(整数)

hincrbyfloat(name, key, amount=1.0)

1
2
3
4
5
6
7
8
# 自增name对应的hash中的指定key的值,不存在则创建key=amount
# 参数:
    # name,redis中的name
    # key, hash对应的key
    # amount,自增数(浮点数)
# 自增name对应的hash中的指定key的值,不存在则创建key=amount

hscan(name, cursor=0, match=None, count=None)

1
2
3
4
5
6
7
8
9
10
11
12
13
# 增量式迭代获取,对于数据大的数据非常有用,hscan可以实现分片的获取数据,并非一次性将数据全部获取完,从而放置内存被撑爆
# 参数:
    # name,redis的name
    # cursor,游标(基于游标分批取获取数据)
    # match,匹配指定key,默认None 表示所有的key
    # count,每次分片最少获取个数,默认None表示采用Redis的默认分片个数
# 如:
    # 第一次:cursor1, data1 = r.hscan('xx', cursor=0, match=None, count=None)
    # 第二次:cursor2, data1 = r.hscan('xx', cursor=cursor1, match=None, count=None)
    # ...
    # 直到返回值cursor的值为0时,表示数据已经通过分片获取完毕

hscan_iter(name, match=None, count=None)

1
2
3
4
5
6
7
8
9
# 利用yield封装hscan创建生成器,实现分批去redis中获取数据
# 参数:
    # match,匹配指定key,默认None 表示所有的key
    # count,每次分片最少获取个数,默认None表示采用Redis的默认分片个数
# 如:
    # for item in r.hscan_iter('xx'):
    #     print item

更多参见:https://github.com/andymccurdy/redis-py/

http://doc.redisfans.com/

最新文章

  1. Webpack 中文指南
  2. 《Java并发编程实战》学习笔记 任务执行和取消关闭
  3. XSS防御篇
  4. C语言的几个有趣问题
  5. Windows Azure 社区新闻综述(#68 版)
  6. Tigase XMPP Server在CentOS部署和配置
  7. 换行符在ajax中返回json,eval时发生的 Unexpected token ILLEGAL
  8. ios中关于UIImagePickerController的一些知识总结
  9. jenkins coding.net webhook plugin
  10. HBase shell scan 过滤器用法总结
  11. URLConnection(互联网)
  12. 修改BlackLowKey皮肤样式,增加占屏比
  13. android addJavascriptInterface 不能生效 解决办法
  14. 动态加载及Servlet容器加载
  15. Scala语言学习笔记(2)
  16. 神经网络一(用tensorflow搭建简单的神经网络并可视化)
  17. hdu2897找规律
  18. python调用R语言,关联规则可视化
  19. Java学习---异常处理的学习
  20. jquery的基础语法、选取元素、操作元素、加事件、挂事件及移除事件

热门文章

  1. c# 获取Excel内容的分析
  2. STM32F10x_SPI(硬件接口 + 软件模拟)读写Flash(25Q16)
  3. flutter 环境
  4. hdu6070 Dirt Ratio 二分+线段树
  5. WCF系列 基础概念
  6. yii2 basic 简洁安装教程
  7. log4j详解(转)
  8. App上传到应用宝的一些问题
  9. uWSGI配置(转 )
  10. [越狱开发] theOpenDev配置与搭建碰到的问题