根据psycopg2: insert multiple rows with a query,使用 psycopg2 的execute而不是executemany效率更高。其他人可以确认吗?
上面的 StackOverflow 问题建议使用mogrify来创建这样的语句:
INSERT INTO table VALUES (value1, value2), (value3, value4)
是否可以使用常规执行函数生成这样的语句?我想到了一些形式
cursor.execute("""INSERT INTO table VALUES (%s, %s), (%s, %s)""", ((value1,value2),(value3,value4)))
会工作。
更新:
例如,我尝试传入执行 sql 语句:
insert into history (timestamp) values (%s),(%s);
使用以下元组:
(('2014-04-27 14:07:30.000000',), ('2014-04-27 14:07:35.000000',))
但我得到的只是错误:
没有要获取的结果