因此,我有以下代码将旧数据库的数据插入到新数据库中:
...
cur_old.execute("""SELECT DISTINCT module FROM all_students_users_log_course266""")
module_rows = cur_old.fetchall()
for row in module_rows:
cur_new.execute("""INSERT INTO modules(label) SELECT %s WHERE NOT EXISTS (SELECT 1 FROM modules WHERE label=%s)""", (row[0], row[0]))
...
最后一行执行一个查询,其中标签被插入到新数据库表中。我在pgAdmin
上测试了这个查询,它可以按我的意愿运行。
但是,执行脚本时,modules
表中不会插入任何内容。 (实际上序列已更新,但表中没有数据存储)。
从光标调用execute方法后,是否需要执行其他操作?
(Ps。脚本运行到最后没有任何错误)
答案 0 :(得分:7)
你忘记了connection.commit()
。数据库中的任何更改都必须在连接上提交。例如,sqlite3 documentation在第一个示例中清楚地说明了它:
# Save (commit) the changes.
conn.commit()
psycopg2
documentation中的第一个示例也是如此:
# Make the changes to the database persistent
>>> conn.commit()
答案 1 :(得分:1)
正如Evert所说,commit()丢失了。在代码中始终指定它的另一种方法是使用自动提交功能。
http://initd.org/psycopg/docs/connection.html#connection.autocommit
例如:
with psycopg2.connect("...") as dbconn:
dbconn.autocommit=True