百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python mysql批量更新数据(兼容动态数据库字段、表名)

off999 2025-08-01 20:08 74 浏览 0 评论

一、应用场景

上篇文章我们学会了在pymysql事务中批量插入数据的复用代码,既然有了批量插入,那批量更新和批量删除的操作也少不了。

二、解决思路

为了解决批量删除和批量更新的问题,提出如下思路:

  • 所有更新语句的生成都共用一个入口
  • 更新的数据库字段和参数可动态决定
  • 要操作的表名可动态决定
  • 返回where条件前的sql语句

三、解决办法

  • 这里只演示批量更新的解决办法,批量删除的类似。
  • 跟插入语句不同的是,更新语句的where条件前set的数据才可以进行动态生成sql语句,而where条件后面的需要另外拼接。
  • 例如:
update user_info set name ='头条号_code_space',size='30cm' where id=1 

其中where条件前的sql就是我们要进行动态sql拼接的,通用方法此时只返回where条件前的sql语句。

def common_update_sql(item, table):
    """
    从item的key-value提取要更新的字段,进行更新
    :param item: 要执行更新的字段的字典,{"colunm_name_1":"colunm_value_1","colunm_name_2":"colunm_value_2"}
    :param table: 数据库表名
    :return: 返回拼接好的where条件前的sql更新语句
    """
    update = ','.join([" {key} = %s".format(key=key) for key in item])
    update_sql = 'update {table} set '.format(table=table) + update
    return update_sql

四、测试demo

# -*- coding: utf-8 -*-
"""
@Time : 2022/1/29 12:50
@Auth : 技术空间
@File :handle_list_sql_demo2.py
@IDE :PyCharm
@Motto:技术总是要日积月累的

"""
import pymysql


def common_update_sql(item, table):
    """
    从item的key-value提取要更新的字段,进行更新
    :param item: 要执行更新的字段的字典,{"colunm_name_1":"colunm_value_1","colunm_name_2":"colunm_value_2"}
    :param table: 数据库表名
    :return: 返回拼接好的where条件前的sql更新语句
    """
    update = ','.join([" {key} = %s".format(key=key) for key in item])
    update_sql = 'update {table} set '.format(table=table) + update
    return update_sql


def select_list(db_cursor, sql):
    """
    查询数据量表的列表
    :param db_cursor: 游标
    :param sql: 拼接好的sql查询语句
    :return: 返回查询结果列表
    """
    db_cursor.execute(sql)
    data_list = db_cursor.fetchall()
    print(data_list)
    return data_list


if __name__ == '__main__':
    db = pymysql.connect(host='localhost',
                         user='root',
                         password='root',
                         database='others')

    cursor = db.cursor(pymysql.cursors.DictCursor)
    table_1 = "user_info"
    table_2 = "user_role"
    select_user_sql = " select id,name from " + table_1
    select_role_sql = " select user_id,role_id from " + table_2
    try:
        print("执行批量更新user前的数据-->")
        select_list(cursor, select_user_sql)
        update_user_list = []
        for i in range(4, 7):
            update_user_list.append({"name": "头条号_code_space_" + str(i)})
        # 更新user表的id为4,5,6的数据
        for i in range(3):
            update = update_user_list[i]
            update_sql = common_update_sql(update, table_1)
            update_sql = update_sql + " where id=" + str(i + 4)
            cursor.execute(update_sql, tuple(update.values()))

        # 开始批量插入表2
        print("执行批量更新user_role前的数据-->")
        select_list(cursor, select_role_sql)
        update_role_list = []
        for i in range(4, 7):
            update_role_list.append({"user_id": i, "role_id": 2})
        # 更新user_role表的id为4,5,6的数据
        for i in range(3):
            update = update_role_list[i]
            update_sql = common_update_sql(update, table_2)
            update_sql = update_sql + " where id=" + str(i + 4)
            cursor.execute(update_sql, tuple(update.values()))

    except Exception as e:
        # 事务回滚
        db.rollback()
        print('事务处理失败', e)
    else:
        # 事务提交
        db.commit()
        print('事务处理成功', cursor.rowcount)
        print("执行批量更新user后的数据-->")
        select_list(cursor, select_user_sql)
        print("执行批量更新user_role后的数据-->")
        select_list(cursor, select_role_sql)
    cursor.close()
    db.close()

关注我,坚持每日积累一个技巧,长期坚持,我们将会不断进步。

#python##程序员##请回答,你的年度知识点##教育听我说##计算机#

相关推荐

window10安装密钥(win10安装密钥命令)

以专业版为例,win10密钥是由25个字符组成的代码,用于激活windows,根据用户获取windows10副本的方式,需要由25个字符组成的产品密钥或数字许可证才能激活它。数字许可证是windows...

电脑windows7无法连接到网络

解决方法:1、在使用电脑的时候,出现了网络连接不可用的问题,可能造成的原因主要有网络连接被禁用,DNS和IP地址获取不对,网卡驱动损坏,网线没有插好。2、鼠标右键网络连接图标进去,点击更改适配器设置。...

路由器静态ip填什么(路由器的静态ip)

手机登入路由器web界面,输入用户名和密码,第一次弹出设置向导,选择静态ip上网方式,填写可以上网的ip地址,如ip192.168.1.188子网掩码255.255.255.0网关192.168....

台式机显卡怎么安装(台式机显卡如何安装快速回答)
  • 台式机显卡怎么安装(台式机显卡如何安装快速回答)
  • 台式机显卡怎么安装(台式机显卡如何安装快速回答)
  • 台式机显卡怎么安装(台式机显卡如何安装快速回答)
  • 台式机显卡怎么安装(台式机显卡如何安装快速回答)
安装声卡驱动(安装声卡驱动无法找到可支援的驱动程序)
  • 安装声卡驱动(安装声卡驱动无法找到可支援的驱动程序)
  • 安装声卡驱动(安装声卡驱动无法找到可支援的驱动程序)
  • 安装声卡驱动(安装声卡驱动无法找到可支援的驱动程序)
  • 安装声卡驱动(安装声卡驱动无法找到可支援的驱动程序)
电脑频繁断电关机(电脑经常断电是不是电源的问题)

电脑自动关机主要有以下几种原因造成:1.散热不好。由于天气温度的影响或CPU风扇的转数不够所引起的系统过热,从而会导致电脑的自动关机,建议可以检查一下系统温度是否正常。2.内存原因。当内存与主板插...

华为手机双密码双界面(华为手机双密码双界面忘记密码了怎么办)

华为手机锁屏怎么有两个锁屏?通常情况下是你多设置了一个锁屏,第一个就是你手势。锁屏二个是密码锁屏,通常这两个同时使用会出现有两个锁屏的现象。你可以在设置里面重新设置一个锁屏就可以了。华为手机锁屏有两个...

无线路由器密码在哪看(无线路由器密码在哪里看)

笔记本已连接wifi密码查看:1.同时按住按键上面的Win和R这2个按键,打开运行程序。2.在运行程序中输入“ncpa.cpl”,并点击“确定”。3.找到WLAN或者无线网络连接图标,...

office2003的主要功能(word2003的主要功能)

是一套Office2003专业版的精简版,包含常用的Word、Excel、PowerPoint三个应用,使用者甚多。楼主如果有需要,请上电脑在本帖下载我的附件。

ie浏览器异常怎么修复(ie浏览器出现问题怎么办)
  • ie浏览器异常怎么修复(ie浏览器出现问题怎么办)
  • ie浏览器异常怎么修复(ie浏览器出现问题怎么办)
  • ie浏览器异常怎么修复(ie浏览器出现问题怎么办)
  • ie浏览器异常怎么修复(ie浏览器出现问题怎么办)
怎样准备一个带pe的u盘的(带pe系统的u盘)

一、U盘安装系统前期准备:  1、首先需要预备一个空的4G或以上U盘,用来存储启动程序跟系统文件。  2、接着我们需要安装的ghost系统。  3、U盘启动盘制作工具:U盘启动工具  二、U盘启动盘制...

怎样拷贝文件到u盘里(怎么文件拷贝到u盘)

方法/步骤分步阅读1点击安全打开等电脑的桌面中弹出U盘插入成功的提示框之后,点击安全打开,将U盘打开。2点击文件将U盘打开之后,在电脑的桌面中找到需要拷贝的文件,点击鼠标右键等弹出序列。3点击复制弹出...

固态硬盘怎么安装win7(固态硬盘怎么安装在电脑上)
固态硬盘怎么安装win7(固态硬盘怎么安装在电脑上)

1.首选需要找一个4GB以上的U盘2.用来存放Win7的ISO镜像文件。带有光盘标识的即为“光盘映像文件”3.在点击写入之前,一定要确保U盘里面没有任何数据,如果有数据应该及时备份,否则里面的数据将被删除,不过在做完启动盘后,仍然可以向里面...

2025-12-27 13:03 off999

苹果手机忘记密码怎么办(很久没用的苹果手机忘记密码怎么办)

在苹果官网中搜索忘记iphone密码,点击置于恢复模式的链接,根据步骤完成解锁即可,以下是详细的操作步骤:方法/步骤1点击搜索图标网页上搜索进入apple官网,进入官网主页面之后,点击页面上方的放大镜...

win10系统防火墙在哪里设置(windows10的防火墙怎么设置)

Windows10的防火墙设置非常简单。首先,您可以点击“开始”菜单,然后在搜索框中输入“防火墙”来打开防火墙设置。接下来,您可以根据需要为不同的网络(包括公用网络、专用网络和域网络)设置不同的防火...

取消回复欢迎 发表评论: