1. 程式人生 > >Android開發系列(十七):讀取assets文件夾下的數據庫文件

Android開發系列(十七):讀取assets文件夾下的數據庫文件

pack 取數 code ada tracking 編寫 數據庫 sdn where

在做Android應用的時候,不可避免要用到數據庫。可是當我們把應用的apk部署到真機上的時候,已經創建好的數據庫及其裏邊的數據是不能隨著apk一起安裝到真機上的。

(PS:這篇博客攻克了我前面博客中寫的一個小遊戲的一個問題。另外也能夠讀取Raw文件夾下的數據庫文件)

這就造成了一個問題。這個問題事實上非常好解決,解決方法例如以下:

我們首先把有數據的數據庫文件放在assets資源文件夾下邊,然後在apk應用啟動的時候,把assets文件夾下的數據庫文件的數據寫入到真機的內存中去。



下邊開始我們的代碼編寫:

首先。我們建立一個datab的Android Project命名為datab,我們把project的文件夾視圖貼出來:

技術分享

我們首先要創建一個數據庫,能夠在DatabActivity.java中用sql語句創建,然後插入幾條數據。然後把創建好而且插入數據的數據庫放入assets目錄下邊。

我們看下我放入的test.db數據庫的結構:

技術分享

能夠看到。在test.db中我們插入了三條數據。


接下來,我們就是要在應用啟動的時候讀取assets文件夾下的數據庫,然後把test.db寫入SDcard的data/data/com.datab.cn路徑下邊。

我們首先新建一個類:SQLdm.java:

<span style="font-size:18px;">package com.datab.cn;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;

import android.content.Context;
import android.content.res.AssetManager;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log;

/**
 * 這個類就是實現從assets文件夾讀取數據庫文件然後寫入SDcard中,假設在SDcard中存在。就打開數據庫,不存在就從assets文件夾下復制過去
 * @author Big_Adamapple
 *
 */
public class SQLdm {  
	  
    //數據庫存儲路徑  
    String filePath = "data/data/com.datab.cn/test.db";  
    //數據庫存放的文件夾 data/data/com.main.jh 以下  
    String pathStr = "data/data/com.datab.cn";  
      
    SQLiteDatabase database;   
    public  SQLiteDatabase openDatabase(Context context){  
        System.out.println("filePath:"+filePath);  
        File jhPath=new File(filePath);  
            //查看數據庫文件是否存在  
            if(jhPath.exists()){  
            	Log.i("test", "存在數據庫");
                //存在則直接返回打開的數據庫  
                return SQLiteDatabase.openOrCreateDatabase(jhPath, null);  
            }else{  
                //不存在先創建文件夾  
                File path=new File(pathStr);  
                Log.i("test", "pathStr="+path);
                if (path.mkdir()){  
                	Log.i("test", "創建成功"); 
                }else{  
                	Log.i("test", "創建失敗");
                };  
                try {  
                    //得到資源  
                    AssetManager am= context.getAssets();  
                    //得到數據庫的輸入流  
                    InputStream is=am.open("test.db");  
                    Log.i("test", is+"");
                    //用輸出流寫到SDcard上面    
                    FileOutputStream fos=new FileOutputStream(jhPath);  
                    Log.i("test", "fos="+fos);
                    Log.i("test", "jhPath="+jhPath);
                    //創建byte數組  用於1KB寫一次  
                    byte[] buffer=new byte[1024];  
                    int count = 0;  
                    while((count = is.read(buffer))>0){  
                    	Log.i("test", "得到");
                        fos.write(buffer,0,count);  
                    }  
                    //最後關閉就能夠了  
                    fos.flush();  
                    fos.close();  
                    is.close();  
                } catch (IOException e) {  
                    // TODO Auto-generated catch block  
                    e.printStackTrace();  
                    return null;
                }  
                //假設沒有這個數據庫  我們已經把他寫到SD卡上了。然後在運行一次這種方法 就能夠返回數據庫了  
                return openDatabase(context);  
            }  
    }  
}
</span>

然後,我們在DatabActivity.java中獲得數據庫中的數據:

<span style="font-size:18px;">package com.datab.cn;

import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.widget.TextView;

public class DatabActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
        //打開數據庫輸出流
        SQLdm s = new SQLdm();
        SQLiteDatabase db =s.openDatabase(getApplicationContext()); 
        
        TextView textv = (TextView) findViewById(R.id.textv);
        //查詢數據庫中testid=1的數據
        Cursor cursor = db.rawQuery("select * from testbiao where testid=?", new String[]{"1"}); 
        String name = null;
        if(cursor.moveToFirst()){  
            name = cursor.getString(cursor.getColumnIndex("name"));
        }  
        //這是一個TextView,把得到的數據庫中的name顯示出來.
        textv.setText(name);
        cursor.close();  
    }
}</span>
我們的main.xml視圖也貼出來吧,非常easy。一看就懂了。

技術分享

然後。我們在虛擬機上看看我們的界面是什麽樣的:


技術分享

能夠看到,我們得到了數據庫中的數據了,接下來大家能夠把bin文件夾下的apk文件放入到真機中測試,依舊會得到數據庫中的數據

Android開發系列(十七):讀取assets文件夾下的數據庫文件