(Python)批量更新MySQL 42万条数据

今天在编写Python程序进行数据库的Update操作时,发现更新一条数据大概需要0.5秒
在这里插入图片描述
粗略计算一下,更新42万条大概需要58个小时,因此在执行大数据量更新的时候一条条进行更新基本行不通,除非你非常有耐心。通过查阅资料发现有三种优化方法

  • MySQL自带的批量更新
  • 存储过程
  • 建立索引

对于存储过程和索引我用的比较少,所以这里我用了第一种方法。
以表nine_tuple(包含列N_T_ID和SENTI_VALUE)为例,然后需要从文本文件senti_values.txt中读取N_T_ID和SENTI_VALUE值,并根据N_T_ID来更新SENTI_VALUE一列的值
在这里插入图片描述
表1
在这里插入图片描述

MySQL批量插入的语法为:

UPDATE nine_tuple
    SET SENTI_VALUE = CASE N_T_ID 
        WHEN 1 THEN1.57WHEN 2 THEN1.3WHEN 3 THEN1.2END
  • 2
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值