Android sqlite回滚

前端之家收集整理的这篇文章主要介绍了Android sqlite回滚前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在做数据库syn.在sql server和sqlite之间下载数据.如果在sqlite中更新/插入记录时有一些情况,互联网连接速度很慢或者丢失,那么需要回滚.在这段代码中可以使用或者如何在这里使用Transaction.
public void insertTableRecords(String strTableName,String[] strToFields,String[] strValues){
    DBAdapter dbAdapter = DBAdapter.getDBAdapterInstance(DownlaodTableActivity.this);
    dbAdapter.openDataBase();
    ContentValues initialValues = new ContentValues();
    for(int i=0 ;i<strToFields.length;i++){
        initialValues.put(strToFields[i],strValues[i]);
    }
    long n = dbAdapter.insertRecordsInDB(strTableName,null,initialValues);
    System.out.println( " -- inserted status : --- " + n);
}

请帮帮我.

提前致谢…

解决方法

以下是在sqlite中使用事务的简短示例(db是以下sqliteDatabase实例):
try {
    db.beginTransaction();
    // your sql stuff
    db.setTransactionSuccessful();
} catch(sqlException e) {
    // do some error handling
} finally {
   db.endTransaction();
}

请注意,重要的是,无论您选择用“throw”和“异常”替换“//您的sql”的方法.使用insertOrThrow()或者如果您需要更多的灵活性sqliteStatement实例(它们的.execute方法总是引发异常错误).

请注意,您不需要明确回滚.如果调用db.endTransaction()而没有.setTransactionSuccessful(),它将自动回滚.

只要记住总是在你的最后一个sqlException抛出方法后放置setTransactionSuccessful

猜你在找的Android相关文章