python 用 "on duplicate key update"执行很多?

标签 python mysql-python

我正在尝试使用以下脚本在 python 中执行重复 key 更新:

# data from a previous query (returns 4 integers in each row)
rows = first_cursor.fetchall()

query="""
INSERT INTO data (a, b, c)
VALUES (%s,%s,%s) ON DUPLICATE KEY UPDATE a=%s
"""
second_cursor.executemany(query,rows)

我收到这个错误:

File "/usr/lib/pymodules/python2.6/MySQLdb/cursors.py", line 212, in executemany
  self.errorhandler(self, TypeError, msg)
File "/usr/lib/pymodules/python2.6/MySQLdb/connections.py", line 35, in defaulterrorhandler
  raise errorclass, errorvalue
TypeError: not all arguments converted during string formatting

这甚至可以在不创建我自己的循环的情况下实现吗?

最佳答案

这是 MySQLdb 中的一个错误,因为 MySQLdb 使用正则表达式来解析 INSERT 语句:

/usr/lib/pymodules/python2.7/MySQLdb/cursors.py中:

restr = (r"\svalues\s*"
        r"(\(((?<!\\)'[^\)]*?\)[^\)]*(?<!\\)?'"
        r"|[^\(\)]|"
        r"(?:\([^\)]*\))"
        r")+\))")

insert_values= re.compile(restr)

虽然已经有无数bug reports关于这个已经解决的问题,我能够在 MySQLdb 版本 1.2.3 中重现错误。 (注意此时MySQLdb的latest version为1.2.4b4。)

也许这个错误是可以修复的,我真的不知道。但我认为这只是冰山一角——它表明更多的麻烦还潜伏在更深的地方。例如,您可以有一个 INSERT ... SELECT 语句,其中包含嵌套的 SELECT 语句,其中包含 WHERE 条件和参数...处理这些情况的正则表达式越来越复杂,在我看来就像一场失败的战斗。

你可以使用 oursql ;它不使用正则表达式或字符串格式。它将参数化查询和参数分别传递给服务器。

关于python 用 "on duplicate key update"执行很多?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12825232/

相关文章:

python - tf.print 不会在正在评估的节点上打印 sess

python - ValueError : Layer weight shape (43, 100) 与提供的权重形状不兼容 (412457, 400)

python - 如何使用点绘制 Pandas 数据框的两列

python - MySQLdb安装问题

Python MySQLdb - 在查询中使用 '%' 的类型错误

python - Python 中的 slice() 函数有什么作用?

python - Pandas 中的 SettingWithCopyWarning 异常行为

python - MySQL-Python安装错误: Possible Architecture Incompatibility?

python - 如何更快地将更大的.sql文件执行到数据库?

python - MySQLdb Like 带有通配符的运算符