我查看了文档,但没有找到任何东西可以让我知道我通过 cursor.execute("...") 执行的最后一个命令是否成功。
我期待像“1 行受影响”这样的回复。
这是一个老问题,但检查操作是否成功的一种方法psycopg2
是在rowcount
语句之后查看光标的属性。此属性返回受最后一条execute
语句影响的行数。
例如
connection = psycopg2.connect(dbname="foo",user="postgres")
cur = connection.cursor()
cur.execute("INSERT INTO foo VALUES (%s, %s)", (1,2))
cur.rowcount # returns 1
cur.execute("SELECT * FROM foo")
cur.rowcount # returns 0
一个类似的属性是statusmessage
,它返回一个字符串,包括最后执行的操作的类型以及受影响的行数。