Вопрос:

Резервное копирование базы данных SQLite на SD-карту

android sqlite

839 просмотра

3 ответа

11 Репутация автора

Я пытаюсь сделать резервную копию моей базы данных sqlite на моей SDCard, и я пытаюсь следовать таким образом, но я не могу найти базу данных в моей SDCard Что я сделал не так?

public void exportDatabse(String DBOperations) {

    try {
        File sd = Environment.getExternalStorageDirectory();
        File data = Environment.getDataDirectory();

        if (sd.canWrite()) {
            String currentDBPath = "//data//com.example.hp.semakoperasimampatansrc//databases//attendant_info.db";
            String backupDBPath = "attendant_info_backup.db";
            File currentDB = new File(data, currentDBPath);
            File backupDB = new File(sd, backupDBPath);

            if (currentDB.exists()) {
                FileChannel src = new FileInputStream(currentDB).getChannel();
                FileChannel dst = new FileOutputStream(backupDB).getChannel();
                dst.transferFrom(src, 0, src.size());
                src.close();
                dst.close();
            }
        }
    } catch (Exception e) {
    }

Как я называю метод:

db.exportDatabse("attendant_info.db");

Я также добавил

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

к моему манифесту

Автор: Eizzuddin Источник Размещён: 11.05.2017 08:41

Ответы (3)


0 плюса

1511 Репутация автора

Решение

Попробуйте добавить запрос разрешения времени выполнения для Android 6.0 (API уровня 23) и выше из официальных документов.

Код для получения WRITE_EXTERNAL_STORAGEразрешения

if (Build.VERSION.SDK_INT > Build.VERSION_CODES.LOLLIPOP_MR1 && !checkIfAlreadyhavePermission()) {
        requestForSpecificPermission();
    }

private boolean checkIfAlreadyhavePermission() {
    if (checkSelfPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {
        return false;
    }
    return true;
}

Спросите разрешение еще как это

private void requestForSpecificPermission() {
    requestPermissions(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, 101);
}
Автор: shadygoneinsane Размещён: 11.05.2017 08:55

2 плюса

471 Репутация автора

Вы можете сделать то же самое следующим образом, и это можно использовать для копирования не только базы данных, но и файлов и общих префов (если есть). Создайте класс с именем DeveloperOption и используйте его метод copyAppDataToLocal, чтобы сделать то же самое.

Разрешение во время выполнения требуется, если целевой SDK 23 или выше

//package declaration
import android.app.Activity;
import android.os.Environment;
import android.util.Log;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;

public class DeveloperOption {
    public static final String BASE_PATH = Environment.getExternalStoragePublicDirectory
            ("App_BackUp").getAbsolutePath();
    public static final String SEPARATOR = "/";
    private static boolean operationStatus = true;
    private static String dataDirectory = null;
    private static String appName = "APP_NAME";

    public static boolean copyAppDataToLocal(Activity callingActivity, String appName) {

        dataDirectory = callingActivity.getApplicationInfo().dataDir;
        DeveloperOption.appName = appName;
        String TAG = "Developer_Option";
        try {
            if(dataDirectory != null) {
                copyAppData(new File(dataDirectory, "shared_prefs"),"shared_prefs");
                copyAppData(new File(dataDirectory, "files"),"files");
                copyAppData(new File(dataDirectory, "databases"),"databases");
            } else {
                Log.e(TAG, "!!!!!Unable to get data directory for ACTIVITY-->" + callingActivity
                        .toString());
            }
        } catch (Exception ex) {
            Log.e(TAG, "!!!!@@@Exception Occurred while copying DATA--->"+ex.getMessage(),ex.fillInStackTrace());
            operationStatus = false;
        }

        return operationStatus;
    }

    private static void copyFileToStorage(String directoryName, String inFile, String fileName, boolean
            isDirectory, String subdirectoryName) {
        try {
            FileInputStream myInput = new FileInputStream(inFile);
            File out_dir;
            if(!isDirectory) {
                out_dir = new File(BASE_PATH+ SEPARATOR + appName +
                        SEPARATOR + directoryName);
            } else {
                out_dir = new File(BASE_PATH + SEPARATOR + appName +
                        SEPARATOR + directoryName + SEPARATOR + subdirectoryName);
            }
            if(!out_dir.exists()) {
                operationStatus = out_dir.mkdirs();
            }
            String outFileName = out_dir + "/" + fileName;
            OutputStream myOutput = new FileOutputStream(outFileName);
            byte[] buffer1 = new byte[1024];
            int length;
            while ((length = myInput.read(buffer1)) > 0) {
                myOutput.write(buffer1, 0, length);
            }
            myOutput.flush();
            myOutput.close();
            myInput.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    private static void copyAppData(File fileTypeToBeCopied, String outDirectoryName){
        if(fileTypeToBeCopied.exists() && fileTypeToBeCopied.isDirectory()) {
            File[] files = fileTypeToBeCopied.listFiles();
            for (File file : files) {
                if(file.isFile()) {
                    copyFileToStorage(outDirectoryName, file.getAbsolutePath(), file.getName(), false, "");
                } else {
                    String folderName = file.getName();
                    File databaseDirsNew = new File(dataDirectory, outDirectoryName+"/" + folderName);
                    if(databaseDirsNew.exists() && databaseDirsNew.isDirectory()) {
                        File[] filesDB = databaseDirsNew.listFiles();
                        for (File file1 : filesDB) {
                            if(file1.isFile()) {
                                copyFileToStorage(outDirectoryName, file1.getAbsolutePath(), file1.getName(),
                                        true, folderName);
                            }
                        }
                    }
                }
            }
        }
    }
}
Автор: Aashish Aadarsh Размещён: 11.05.2017 08:56

0 плюса

715 Репутация автора

попробуй это.

public void exportDatabse(String DBOperations){
    File sd = Environment.getExternalStorageDirectory();
        File data = Environment.getDataDirectory();
       FileChannel source=null;
       FileChannel destination=null;
       String currentDBPath = "//data//com.example.hp.semakoperasimampatansrc//databases//attendant_info.db";
       String backupDBPath = DBOperations;
       File currentDB = new File(data, currentDBPath);
       File backupDB = new File(sd, backupDBPath);
       try {
            source = new FileInputStream(currentDB).getChannel();
            destination = new FileOutputStream(backupDB).getChannel();
            destination.transferFrom(source, 0, source.size());
            source.close();
            destination.close();
            Toast.makeText(this, "DB Exported!", Toast.LENGTH_LONG).show();
        } catch(IOException e) {
            e.printStackTrace();
        }
}
Автор: jai khambhayta Размещён: 11.05.2017 08:59
Вопросы из категории :
32x32