是否可以在python中提交后回滚sqlite3更改

时间:2017-08-01 17:34:36

标签: python python-3.x sqlite

我通过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()

1 个答案:

答案 0 :(得分:3)

这是不可能的。事务提交后,所有更改都将合并到数据库中,并且与其他数据无法区分。

如果要稍后还原更改,则不仅要存储更改的结果,还要存储足够的信息以还原数据库中的更改。 有关示例,请参阅Automatic Undo/Redo Using SQLite