如何在 psycopg2 中的列值中添加引号/撇号?


information = "Hope they're well"     
cursor.execute("UPDATE table_name SET information='%s';" % information)

添加它时,它显然会产生错误,因为执行只会尝试添加"希望他们",然后字符串的其余部分会搞砸它。

显然,在 php 中可以选择进行预准备语句,那么如何在 psycopg2 中做到这一点呢?

我读了这篇文章,但不太明白它以及它是否是我想做的。

不要格式化字符串,只需将您的值作为第二个参数传递:

cursor.execute("UPDATE mytable SET col1 = %s, col2 = %s;", [arg1, arg2])

(可选)使用命名参数并传递字典:

cursor.execute("""
    UPDATE mytable
    SET col1 = %(arg1)s, col2 = %(arg2)s
""",{'arg1':arg1, 'arg2':arg2})

psycopg2会处理其他一切。

有关更多信息,请参阅此处。

最新更新