蟒蛇执行多用“的重复键更新”?(python execute many with “on dupli

2019-08-01 08:21发布

我想在Python一起executemany上的重复密钥更新,用下面的脚本:

# 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

这甚至可能没有创造我自己的循环?

Answer 1:

这是MySQLdb的错误归因于MySQLdb的使用来解析正则表达式的INSERT语句:

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

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

insert_values= re.compile(restr)

虽然已经有不少错误报告有关此问题为固定已关闭,我能够重现错误MySQLdb的版本1.2.3。 (请注意, 最新版本的 MySQLdb的此刻是1.2.4b4。)

也许这个错误是可以解决的,我真的不知道。 但我认为这只是冰山一角 - 它指向更麻烦只是潜伏更深一点。 你可以有例如一个INSERT ... SELECT与嵌套语句SELECT与语句WHERE条件和参数洒一回事...使正则表达式越来越复杂处理这些情况我看来,像一场败仗。

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



Answer 2:

当你写的SQL像下面:

sql = insert into A (id, last_date, count) values(%s, %s, %s) on duplicate key update last_date=%s, count=count+%s'

您会收到以下错误: TypeError: not all arguments converted during string formatting.

所以,当你使用"ON DUPLICATE KEY UPDATE"的蟒蛇,你需要写这样的SQL:

sql = 'insert into A (id, last_date, count) values(%s, %s, %s) on duplicate key update last_date=values(last_date),count=count+values(count)' 


Answer 3:

这是MySQLdb的一个问题,问题的Ubuntu说,悦目更改SQL那么它的工作原理:

insert into tb_name(col1, col2) select 1,2 on duplicate key update col1=1


Answer 4:

发现:

on duplicate key update col1=VALUES(col1), col2=VALUES(col2)

https://hardforum.com/threads/python-mysql-not-all-arguments-converted-during-string-formatting.1367039/



文章来源: python execute many with “on duplicate key update”?