Я пытаюсь импортировать базу данных sqlite, чтобы она перезаписывала ту, что есть в данный момент. Мне удалось экспортировать базу данных в файл в папке на телефоне, но когда я пытаюсь импортировать ее, я получаю исключение, которое говорит: «Нет такого файла или каталога». Как это исправить?
Это мой код для экспорта базы данных в файл
private void exportDB() {
try {
File sd = Environment.getExternalStorageDirectory();
File data = Environment.getDataDirectory();
if (sd.canWrite()) {
String currentDBPath= "//data//" + "com.varcon.campus"
+ "//databases//" + "CampusTime.db";
String backupDBPath = "/Download/CampusTime";
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();
}
}
Файл успешно экспортирован в папку с его именем Это мой код для импорта база данных
int PICKFILE_RESULT_CODE = 1;
Intent chooseFile = new Intent(Intent.ACTION_GET_CONTENT);
chooseFile.setType("*/*");
chooseFile = Intent.createChooser(chooseFile, "Choose a file");
startActivityForResult(chooseFile, PICKFILE_RESULT_CODE);
@Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent datas) {
Uri uri = datas.getData();
String filePath = uri.getPath();
try {
//Toast.makeText(this, ""+src, Toast.LENGTH_LONG).show();
try {
File sd = Environment.getExternalStorageDirectory();
File data = Environment.getDataDirectory();
if (sd.canWrite()) {
String currentDBPath= "//data//" + "com.varcon.campus"
+ "//databases//" + "CampusTime.db";
String backupDBPath = filePath;
File backupDB= new File(data, currentDBPath);
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();
Toast.makeText(getBaseContext(), backupDB.toString(),
Toast.LENGTH_LONG).show();
}
} catch (Exception e) {
Toast.makeText(getBaseContext(), e.toString(), Toast.LENGTH_LONG)
.show();
}
//new CustomMessage(getActivity(), "Database replaced sucessfully");
} catch (Exception e) {
e.printStackTrace();
//CustomLog.showLogD("WORKING_STOP",e.getMessage());
}
super.onActivityResult(requestCode, resultCode, datas);
}
И у меня есть разрешения в моем доступном манифесте
Stacktrace:
2020-03-10 23:14:43.704 31088-31088/com.varcon.campus D/error: java.io.FileNotFoundException: /storage/emulated/0/Download/CampusTime (No such file or directory)