1

这是我使用 ORMLITE 保存在 sqlite db 中的模型类。

public class Site{
                 ...
                 ...
                 Collection<Visit> visits;
                 }

public class Visit{
                 ...
                 ...
                 Collection<Pic> pics;
                 }

public class Pic{
                 ...
                 ...

                 }

现在在一个视图中,我从这三个表中添加、编辑或删除。我认为有一个按钮可以取消更改(添加、编辑、删除)。所以我需要回滚到数据库的先前状态。

我怎样才能使用带有android的ormlite实现回滚到三个表的某个状态?

我已经阅读了有关DAO.SetAutoCommit()startThreadConnection()方法的 ormlite 文档。我想我可以通过使用这两个来做到这一点。但无法弄清楚如何使用它们。请建议我怎么做。

这是我的 DBHelper 类:

public class DatabaseHelper extends OrmLiteSqliteOpenHelper {
// name of the database file 
private static final String DATABASE_NAME = "Test.db";


private static final int DATABASE_VERSION = 1;

private Dao<Site, Integer> siteListDao = null;
private Dao<Visit, Integer> visitDao= null;
private Dao<Pic,Integer> picDao=null;

    public DatabaseHelper(Context context) {
    super(context, DATABASE_NAME, null, DATABASE_VERSION);
}

@Override
public void onCreate(SQLiteDatabase database,ConnectionSource connectionSource) {
    try {
        TableUtils.createTable(connectionSource, Site.class);
        TableUtils.createTable(connectionSource, Visit.class);
        TableUtils.createTable(connectionSource, Pic.class);
                 } catch (SQLException e) {
        Log.e(DatabaseHelper.class.getName(), "Can't create database", e);
        throw new RuntimeException(e);
    } catch (java.sql.SQLException e) {
        e.printStackTrace();
    }

}

    public Dao<Visit, Integer> getVisitDao() {
    if (null == visitDao) {
        try {
            visitDao = getDao(Visit.class);
        }catch (java.sql.SQLException e) {
            e.printStackTrace();
        }
    }
    return visitDao;
}
    .....
     .....
4

2 回答 2

2

嗯,不知道有什么方法可以自动为您执行此操作。如果你真的想自动完成,你也可以查看 Transactions。它们具有内置控件,可在失败时回滚。不完全是你想要的,但也许可以调整。

您也可以手动进行更多操作,并将 1 个(最后一个)对象保存在内存中,即您要删除的对象。如果有人想“撤消”更改,您可以使用 ORMLite 重新添加该对象。可能比其他选项容易得多。

于 2013-03-26T10:48:00.133 回答
1

是的,我大多同意@Stefan。我认为您需要在您的应用程序内部执行此操作,而不是依赖数据库构造来返回之前的状态。

关闭自动提交(ORMLite使用 Sqlite 下的事务)或直接使用事务不是这样做的。事务旨在允许您对数据库进行多项更改,然后在一次数据库更改失败时将它们全部回滚。它们不打算在等待用户输入的几秒钟内保持打开状态。

  • 您可以在数据中包含已提交的布尔字段或类似的字段,以便通过删除所有对象committed = false或类似的对象来更轻松地“恢复”数据库。
  • 您可以有单独的表,以便将对象存储到会话表中,然后在用户提交工作时复制到主表中。
于 2013-03-26T12:19:30.587 回答