Как я могу автоматически создать резервную копию моей базы данных на SD-карте в своем приложении? И потом, как мне его восстановить?
Резервное копирование и восстановление базы данных SQLite на SDCard
Ответ 1
Вот мой код:
// Local database
InputStream input = new FileInputStream(from);
// create directory for backup
File dir = new File(DB_BACKUP_PATH);
dir.mkdir();
// Path to the external backup
OutputStream output = new FileOutputStream(to);
// transfer bytes from the Input File to the Output File
byte[] buffer = new byte[1024];
int length;
while ((length = input.read(buffer))>0) {
output.write(buffer, 0, length);
}
output.flush();
output.close();
input.close();
Ответ 2
Как я могу создать резервную копию моей базы данных sdcard автоматически в моем приложении?
Скопируйте его с помощью стандартного ввода/вывода Java. Убедитесь, что у вас нет открытых объектов SQLiteDatabase
.
А потом как мне его восстановить?
Скопируйте его с помощью стандартного ввода/вывода Java. Убедитесь, что у вас нет открытых объектов SQLiteDatabase
для старой базы данных.
Вы можете использовать getPath()
для объекта SQLiteDatabase
, чтобы узнать, где он находится, AFAIK (не пробовал это).
Ответ 3
Благодаря существующим ответам. Вот полный класс (с использованием "getDatabasePath" ):
package com.levionsoftware.bills.data.db;
import android.content.Context;
import android.os.Environment;
import android.widget.Toast;
import com.levionsoftware.bills.MyApplication;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.nio.channels.FileChannel;
/**
* Created by denny on 16/05/2016.
* Source: http://stackoverflow.com/questions/18322401/is-it-posible-backup-and-restore-a-database-file-in-android-non-root-devices
*/
public class BackupAndRestore {
public static void importDB(Context context) {
try {
File sd = Environment.getExternalStorageDirectory();
if (sd.canWrite()) {
File backupDB = context.getDatabasePath(DBHandler.getDBName());
String backupDBPath = String.format("%s.bak", DBHandler.getDBName());
File currentDB = new File(sd, backupDBPath);
FileChannel src = new FileInputStream(currentDB).getChannel();
FileChannel dst = new FileOutputStream(backupDB).getChannel();
dst.transferFrom(src, 0, src.size());
src.close();
dst.close();
MyApplication.toastSomething(context, "Import Successful!");
}
} catch (Exception e) {
e.printStackTrace();
}
}
public static void exportDB(Context context) {
try {
File sd = Environment.getExternalStorageDirectory();
File data = Environment.getDataDirectory();
if (sd.canWrite()) {
String backupDBPath = String.format("%s.bak", DBHandler.getDBName());
File currentDB = context.getDatabasePath(DBHandler.getDBName());
File backupDB = new File(sd, backupDBPath);
FileChannel src = new FileInputStream(currentDB).getChannel();
FileChannel dst = new FileOutputStream(backupDB).getChannel();
dst.transferFrom(src, 0, src.size());
src.close();
dst.close();
MyApplication.toastSomething(context, "Backup Successful!");
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
Ответ 4
fooobar.com/info/424245/...
Ответ выше на дублированный вопрос представляет собой отличный пример импорта и экспорта ваших SQLite-DB на SD-карту. Посмотрите.