Това е основният код на работещо възстановяване на DB (от if (dbfile
.. в try
).
private static final int BUFFERSZ = 32768;
private byte[] buffer = new byte[BUFFERSZ];
........
dbfile = new File(currentdbfilename);
.......
if (dbfile.delete()) {
origdeleted = true;
}
FileInputStream bkp = new FileInputStream(backupfilename);
OutputStream restore = new FileOutputStream(currentdbfilename);
copylength = 0;
while ((copylength = bkp.read(buffer)) > 0) {
restore.write(buffer, 0, copylength);
}
restore.flush();
restore.close();
restoredone = true;
bkp.close();
Основните разлики са, че изтривам DB файла и използвам записи, а не трансфери. По-късно и при успешно възстановяване също използвам следното, за да рестартирам приложението (може да е излишно, но работи за мен), тъй като можете да получите непредвидими резултати (мисля, че части от оригиналната база данни могат да бъдат достъпни от памет/кеширани данни):-
Intent i = getBaseContext().getPackageManager()
.getLaunchIntentForPackage( getBaseContext().getPackageName() );
i.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
finish();
startActivity(i);
System.exit(0);