Android Java Нет такого файла или каталога при импорте базы данных sqlite - PullRequest
0 голосов
/ 10 марта 2020

Я пытаюсь импортировать базу данных 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)

1 Ответ

0 голосов
/ 11 марта 2020

Единственное, что вам нужно сделать, это открыть InputStream для выбранного uri вместо использования FileInputStream для файла.

InputStream is = getContentResolver().openInputStream(data.getData());

Затем читать из потока как обычно.

...