我正在做数据库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(),它将自动回滚.