Скачать файл SQLite программно - PullRequest
1 голос
/ 15 января 2020

В моем приложении android я использую базу данных SQLite. И мне нужно иметь опцию в приложении для загрузки файла базы данных.

Потому что иногда мне нужно просматривать данные там, поэтому пользователь скачивает файл и отправляет его мне, и я просматриваю его, используя Браузеры SQLite.

Это выполнимо? если да как?

   String src = "/data/data/myPackage/databases/Mydb.db";
   String dest = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOWNLOADS).getPath();

copyFileOrDirectory(src , dest);

 public static void copyFileOrDirectory(String srcDir, String dstDir) {

        try {
            File src = new File(srcDir);
            File dst = new File(dstDir, src.getName());

                copyFile(src, dst);

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static void copyFile(File sourceFile, File destFile) throws IOException {
        if (!destFile.getParentFile().exists())
            destFile.getParentFile().mkdirs();

        if (!destFile.exists()) {
            destFile.createNewFile();
        }

        FileChannel source = null;
        FileChannel destination = null;

        try {
            source = new FileInputStream(sourceFile).getChannel();
            destination = new FileOutputStream(destFile).getChannel();
            destination.transferFrom(source, 0, source.size());
        } finally {
            if (source != null) {
                source.close();
            }
            if (destination != null) {
                destination.close();
            }
        }
    }

1 Ответ

1 голос
/ 15 января 2020

Обычно база данных SQLite доступна по пути /data/data/your.applications.package/databases/database.db.

Итак, вы можете использовать этот путь; однако я предлагаю вам получить путь к базе данных следующим образом:

File dbFile = getDatabasePath("dbname");
String dbPath = dbFile.getPath();

Затем вы можете скопировать базу данных из этой папки в нужную папку. Копирование базы данных в Downloads может имитировать «загрузку» базы данных SQLite.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...