独自の MySQL データベースを作成および更新するアプリがあります。ユーザーがデータベースのコピーを(バックアップ目的で)エクスポートし、後でファイルを再度インポートできるようにしたいと考えています。このプロセス中にデータベースの形式を変更する必要はありません。
これを行うための最良/最も簡単な方法についてはわかりません。以下のコードを使用して、アプリでデータベースを SD カードにエクスポートすることができましたが、問題は、アプリでこのファイルを再度インポートするにはどうすればよいかということです。
try {
File sd = Environment.getExternalStorageDirectory();
File data = Environment.getDataDirectory();
Toast.makeText(getBaseContext(), sd.toString(), Toast.LENGTH_LONG).show();
Toast.makeText(getBaseContext(), data.toString(), Toast.LENGTH_LONG).show();
if (sd.canWrite()) {
String currentDBPath = "//data//"+ packageName +"//databases//"+ class_dbname; //dbList[0];
String backupDBPath = "//data//"+ class_dbname; //dbList[0];
File currentDB = new File(data, currentDBPath);
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();
Toast.makeText(getBaseContext(), backupDB.toString(), Toast.LENGTH_LONG).show();
}
} catch (Exception e) {
Toast.makeText(getBaseContext(), e.toString(), Toast.LENGTH_LONG).show();
}