环境

  • windows 10 专业版
  • pycharm pro
  • python 3.7
  • redis library 4.1.4
  • 补充:Windows redis 3.2.100

问题描述

我想向一个 hash 类型的 key 中插入多个 键值对 value。

在 redis-cli 中我可以使用 HMSET 命令实现这种批量插入,但是当我使用 redis library 4.1.4 中的 hmset 方法时报错:DeprecationWarning: Redis.hmset() is deprecated. Use Redis.hset() instead. conn.hmset(article, content)

代码如下:

import time
import redis3conn = redis3.Redis(host='localhost', port=6379, db=0, decode_responses=True)
conn.flushdb()now = time.time()
article = 'article:' + str(1)content = {'title': 'A title','link': 'http://www.google.com','poster': 'username','time': now,'votes': 1,
}conn.hmset(article, content)
print(conn.hgetall(article))

查了一下,根据hmset() uses deprecated command HMSET #1269的说法, hmset 方法从 4.0.0 版本开始就被弃用了。

尽管这里报错,但实际上它还是起作用了,因为它并没有被从 redis library 4.1.4 的 API 源码中移出。

因为它早晚会被移除,我就想从 hmse 迁移到 hset,于是这就产生了一些问题:

  • 怎样使用 hset API。
  • 在使用 hset API时遇到了一些问题。

解决过程

过程及方法一:

使用循环,但这样在处理大数据时会比较慢:

from pyinstrument import Profiler
profiler=Profiler()
profiler.start()
for i in range(100000):for item in content:conn.hset(article, item, content[item])
profiler.stop()
profiler.print()

执行性能如下:

  _     ._   __/__   _ _  _  _ _/_   Recorded: 18:10:52  Samples:  41159/_//_/// /_\ / //_// / //_'/ //     Duration: 41.370    CPU time: 38.547
/   _/                      v4.1.1Program: F:/python基础/操作数据库/redis/test.py41.366 <module>  test.py:8
└─ 40.991 hset  redis3\client.py:3034[130 frames hidden]  redis3, <built-in>8.293 socket.sendall  <built-in>:0

过程及方法二:

根据源码以及hset mapping not working #1396的说法,我使用mapping参数映射一下:

conn.hset(article, mapping=content)

但报错:redis3.exceptions.ResponseError: wrong number of arguments for 'hset' command

按照 redis doc:hset 的说法,mapping 参数应该是支持以 python 字典形式插入 hash 类型的数据的,就在想是不是本地 windows redis 版本的问题,根据[BUG] hset does not support multiple dict mapping #8622中的讨论,去查了一下本地 windows redis 版本:

好家伙,版本太低了,要么直接卸载,然后手动编译重装 6.X 版本,要么还是在 linux 环境操作:

# 查看redis版本
dfl@WEB:/opt/redis-6.0.9$ redis-cli
127.0.0.1:6379> info server
# Server
redis_version:6.0.9

执行官结果如下:

{'title': 'A title', 'link': 'http://www.google.com', 'poster': 'username', 'time': '1648130581.633493', 'votes': '1'}

过程及方法三:

Redis 大量数据插入

Redis——使用 python 操作 redis 之从 hmse 迁移到 hset相关推荐

  1. Python 操作 redis

    官网命令(英文)列表:http://redis.io/commands Redis 教程:http://www.redis.net.cn/tutorial/3501.html Redis 命令参考:h ...

  2. Python操作Redis及连接方式

    前沿:随着互联网的高速发展,数据变得越来越重要,Python成为了人工智能的热门语言,而Nosql数据库已成为日常开发用品. 今天要写的是Python操作Redis Redis的安装我就不介绍了,你可 ...

  3. python 操作redis之——有序集合(sorted set) (七)

    #coding:utf8 import redis r =redis.Redis(host="23.226.74.190",port=63279,password="66 ...

  4. Windows下安装Redis及使用Python操作Redis的方法

    这篇文章主要介绍了Windows下安装Redis及使用Python操作Redis的方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下 首先说一下在Windows下安装Redis,安装包可以在htt ...

  5. python 操作redis之——HyperLogLog (八)

    #coding:utf8 import redis # python 操作redis之--HyperLogLog r =redis.Redis(host="33.23.724.12190&q ...

  6. 用Python操作Redis

    Python操作Redis 首先要安装驱动模块 pip install redis 1.普通连接 import redisr=redis.Redis() # r = redis.Redis(host= ...

  7. python操作redis用法详解

    1.简单介绍 安装redis pip install redis Redis是一个基于内存的高效的键值型非关系型数据库,存取效率极高,而且支持多种存储数据结构,使用也非常简单.本节中,我们就来介绍一下 ...

  8. python redis 操作_使用Python操作redis

    在使用python操作redis之前,需要先安装redis库: pip install redis. 创建连接方式: StrictRedis:实现大部分官方命令. Redis:是StrictRedis ...

  9. Python操作Redis中的hash

    Redis 数据库hash数据类型是一个string类型的key和value的映射表,适用于存储对象.Redis 中每个 hash 可以存储 232 - 1 键值对(40多亿).  Python的re ...

最新文章

  1. Python中的三目运算符------if else 同行
  2. mybatis中like模糊查询的几种写法及注意点
  3. 植入“电商基因” 传统产业搭上网络快车[图]
  4. 。。。。。。想不通的ADO.NET。
  5. springboot ajax返回html
  6. 怎样实现MathType中带箭头向量的输入
  7. TypeScript入坑
  8. jQuery Easy UI ProgressBar(进度条)组件
  9. 案例:演示PreparedStatement对象的使用
  10. 《SPSS 统计分析从入门到精通(第2版)》一6.3 二项式检验
  11. 20届美团提前批面经
  12. Solidity基础入门知识---函数的访问权限和可见性
  13. Windows Shell 编程学习总结
  14. 2016最新一元云购完整源码 云购CMS系统 带安卓和ios手机客户端 源码免费分享
  15. 关于HTML按钮跳转方法(及其相关)
  16. 阿里云服务器使用宝塔面板管理以及项目部署
  17. C#篇-值类型和引用类型
  18. 深入了解示波器(三):示波器的带宽
  19. Jenkins ssh 远程启动 nohup
  20. 放假在家/异地/无法使用学校局域网-如何快速登录知网/web of science等学术平台

热门文章

  1. 白胶浆在印花中的应用
  2. hsc for object detection
  3. 使用leaflet或者openlayers 3 调用MapServer服务最佳实践完整说明
  4. springboot拦截器验证token实现登陆
  5. [NOIP模拟赛]押韵
  6. 服务商快速进件V1.6.3源码帮助客户开通微信支付账号公众号应用
  7. iphone11文件连接服务器显示离线,为什么连不上iphone11的热点?可以这样解决
  8. GO和JAVA如何处理两个数组中的并集和交集
  9. 通过改进销售漏斗提高销售业绩的原因及措施
  10. Python——实现Windows桌面壁纸和bing背景的同步