我通过tkinter按钮点击调用这些功能。因此,一旦完成提交,如果我需要还原更改,我会调用回滚但不会还原更改
def insert(_id,name,phone):
conn = sqlite3.connect(db)
print ("Opened database successfully");
print (name,phone)
conn.execute("INSERT INTO VARUN (ID,NAME,PHONE) \
VALUES (?,?,?)",(_id,name,phone));
conn.commit()
print ("New record(s)" , name," has just been added to the database");
conn.close()
def rollback():
conn = sqlite3.connect(db)
conn.rollback()
print ("\n changes reverted")
conn.close()
答案 0 :(得分:3)
这是不可能的。事务提交后,所有更改都将合并到数据库中,并且与其他数据无法区分。
如果要稍后还原更改,则不仅要存储更改的结果,还要存储足够的信息以还原数据库中的更改。 有关示例,请参阅Automatic Undo/Redo Using SQLite。