2017-01-17 24 views
1

我想給bike_info.db恢復到我的應用程序 數據庫文件中有一些記錄,我想在應用如何恢復的SQLite數據庫備份的Andorid對於非植根設備

我恢復他們嘗試下面的代碼,吐司成功顯示,但數據庫沒有得到恢復,我不知道爲什麼。誰能幫忙?

rest = (Button) findViewById(R.id.cview_restore); 

    rest.setOnClickListener(new OnClickListener() { 
     @Override 
     public void onClick(View v) { 
      try { 
       File sd = Environment.getExternalStorageDirectory(); 
       File data = Environment.getDataDirectory(); 
       if (sd.canWrite()) { 

        String currentDBPath = "//data//" + "com.infyco.kp.new_tab" 
          + "//databases//" + "bike_info.db"; 
        String backupDBPath = "//data//bike_info.db"; // From SD directory. 
        File backupDB = new File(data, currentDBPath); 
        File currentDB = new File(sd, backupDBPath); 

        FileChannel src = new FileInputStream(backupDB).getChannel(); 
        FileChannel dst = new FileOutputStream(currentDB).getChannel(); 
        dst.transferFrom(src, 0, src.size()); 
        src.close(); 
        dst.close(); 
        Toast.makeText(getApplicationContext(), "Import Successful!", 
          Toast.LENGTH_SHORT).show(); 

       } 
      } catch (Exception e) { 

       Toast.makeText(getApplicationContext(), "Import Failed!", Toast.LENGTH_SHORT) 
         .show(); 

      } 
     } 
     }); 

點擊休息按鈕後,這個從Android電子監視器輸出:

01-17 14:00:40.922 8909-8909/com.infyco.kp.new_tab D/ViewRootImpl: ViewPostImeInputStage processPointer 0 
01-17 14:00:40.962 8909-8909/com.infyco.kp.new_tab D/ViewRootImpl: ViewPostImeInputStage processPointer 1 

01-17 14:00:41.012 8909-8909/com.infyco.kp.new_tab D/ViewRootImpl: #1 mView = android.widget.LinearLayout{9ba3ae9 V.E...... ......I. 0,0-0,0 #102039d android:id/toast_layout_root} 

01-17 14:00:41.072 8909-8909/com.infyco.kp.new_tab D/ViewRootImpl: MSG_RESIZED_REPORT: ci=Rect(0, 0 - 0, 0) vi=Rect(0, 0 - 0, 0) or=1 

01-17 14:00:43.022 8909-8909/com.infyco.kp.new_tab D/ViewRootImpl: #3 mView = null 

回答

1

這裏的核心從工作恢復恢復代碼。有一些差異: 我在關閉前沖洗。

我重命名原始數據庫(複製並刪除原始數據),因此它不存在(如果恢復失敗,容易恢復)。

我也在它自己的線程中執行它(這裏沒有顯示)。

我從系統獲取數據庫的路徑/文件名。通過旋塗器

  currentdbfilename = this.getDatabasePath(
       DBConstants.DATABASE_NAME) 
       .getPath(); 

copydbfilename從可用備份的列表中選擇(一個微小的差別是,備份是在外部存儲公共) - :

   dbfile = new File(currentdbfilename);  
       .......    
       try { 
        // Stage 1 Create a copy of the database 
        Log.i(logtag, "Stage 1 (make Copy of current DB)Starting"); 
        FileInputStream fis = new FileInputStream(dbfile); 
        OutputStream backup = new FileOutputStream(copydbfilename); 
        while ((copylength = fis.read(buffer)) > 0) { 
         backup.write(buffer, 0, copylength); 
        } 
        backup.flush(); 
        backup.close(); 
        fis.close(); 
        Log.i(logtag, "Stage 1 - Complete. Copy made of current DB."); 
        copytaken = true; 

        // Stage 2 - Delete the database file 
        if (dbfile.delete()) { 
         Log.i(logtag, "Stage 2 - Completed. Original DB deleted."); 
         origdeleted = true; 
        } 

        // Stage 3 copy from the backup to the deleted database file i.e. create it 
        Log.i(logtag, "Stage 3 - (Create new DB from backup) Starting."); 
        FileInputStream bkp = new FileInputStream(backupfilename); 
        OutputStream restore = new FileOutputStream(currentdbfilename); 
        copylength = 0; 
        while ((copylength = bkp.read(buffer)) > 0) { 
         restore.write(buffer, 0, copylength); 
        } 
        Log.i(logtag, "Stage 3 - Data Written"); 
        restore.flush(); 
        restore.close(); 
        Log.i(logtag, "Stage 3 - New DB file flushed and closed"); 
        restoredone = true; 
        bkp.close(); 
        Log.i(logtag, "Stage 3 - Complete."); 
       } catch (IOException e) { 
        e.printStackTrace(); 
        if(!copytaken) { 
         errlist.add("Restore failed copying current database. Error was " + e.getMessage()); 
        } else { 
         if(!origdeleted) { 
          errlist.add("Restore failed to delete current database. Error was " + e.getMessage()); 
         } 
         else { 
          if(!restoredone) { 
           errlist.add("Restore failed to recreate the database from the backup. Error was "+ e.getMessage()); 
           errlist.add("Restore will attempt to revert to the original database."); 
          } 
         } 
        } 
       } 

currentdbfilename使用設置。