微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

参数不适用于python postgres

我正在将python与postgres一起使用,我正在尝试这个简单的查询,但它不起作用,我无法找到原因

con = psycopg2.connect(**config)


self.cursor.execute("INSERT INTO mytable (id, age, year) VALUES (nextval('my_id_seq'), ?, ?)", ('77', '44'))

我收到此错误

psycopg2.ProgrammingError: Syntax error at or near “,” LINE 1:
…year) VALUES (nextval(‘my_id_seq’), ?, ?)

编辑

这是错误

INSERT INTO mytable (id, age, year) VALUES (nextval('my_id_seq'), %s, %s)
'6.65', '4955/1'

  File "off.py", line 80, in writeRows
    self.cursor.execute(query, values)
TypeError: not all arguments converted during string formatting

码:

data = [('age', '6.65'), ('year', '4974/1'), . . ]
cols = ",".join(data.keys())
qmarks = ','.join(['%s' for s in data.keys()])
query = "INSERT INTO mytable (id, %s) VALUES (nextval('my_id_seq'), %s)" % (cols,qmarks)
self.cursor.execute(query, values)

解决方法:

psycopg2使用pyformat参数样式:

>>> import psycopg2
>>> psycopg2.paramstyle
'pyformat'

更换参数标记?与%s.

参见PEP 249 — Python Database API Specification v2.0 – paramstyle.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐