SQLite
 sql >> Base de Dados >  >> RDS >> SQLite

Como restaurar o banco de dados SQLite após o backup do Android


Este é o código principal de uma restauração de banco de dados em funcionamento (de if (dbfile .. em um 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();

As principais diferenças são que eu excluo o arquivo DB e uso gravações em vez de transferências. Mais tarde e após uma restauração bem-sucedida, também uso o seguinte para reiniciar o aplicativo (pode ser um exagero, mas funciona para mim), pois você pode obter resultados imprevisíveis (acho que partes do banco de dados original podem ser acessadas da memória/dados em cache):-
    Intent i = getBaseContext().getPackageManager()
                                            .getLaunchIntentForPackage( getBaseContext().getPackageName() );


    i.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
    finish();
    startActivity(i);
    System.exit(0);