android開發中,匯入有資料的sqlite,與apk一起安裝到手機上

來源:互聯網
上載者:User

sqlite比較常規的使用方式一般是這樣的,就是在程式中建立一個空的資料庫,然後進行增刪改查等一系列的操作,這樣的操作,對於小應用的開發是比較容易滿足需求的,但是有些比較大的應用,包含的資料量比較大,如果在程式中,對資料進行一條一條的插入,第一,比較耗時,第二,使用者體驗很差,最重要的一點是顯得很不專業。那麼,可以想到的一種比較好的方式,就是如何將db檔案與apk一起安裝到手機上呢,實現方法如下:

首先,要有包含資料的sqlite檔案,是db類型的,可以是你之前一條一條匯入的,然後找到手機路徑下/data/data/包名/database檔案,將其匯出就可以了;

然後,再android工程裡找到assets目錄,將db類型的檔案放在該目錄下面,準備就緒之後,上代碼


[java]
public static SQLiteDatabase database; 

public static SQLiteDatabase database;[java] view plaincopyprint?String DB_PATH = "/data/data/com.example.mymap/databases/"; 
        String DB_NAME = "wifi.db"; 
 
 
        // 檢查 SQLite 資料庫檔案是否存在  
        if ((new File(DB_PATH + DB_NAME)).exists() == false) { 
            // 如 SQLite 資料庫檔案不存在,再檢查一下 database 目錄是否存在  
            File f = new File(DB_PATH); 
            // 如 database 目錄不存在,建立該目錄  
            if (!f.exists()) { 
                f.mkdir(); 
            } 
 
 
            try { 
                // 得到 assets 目錄下我們實現準備好的 SQLite 資料庫作為輸入資料流  
                InputStream is = getBaseContext().getAssets().open(DB_NAME); 
                // 輸出資料流  
                OutputStream os = new FileOutputStream(DB_PATH + DB_NAME); 
 
 
                // 檔案寫入  
                byte[] buffer = new byte[1024]; 
                int length; 
                while ((length = is.read(buffer)) > 0) { 
                    os.write(buffer, 0, length); 
                } 
 
 
                // 關閉檔案流  
                os.flush(); 
                os.close(); 
                is.close(); 
            } catch (Exception e) { 
                e.printStackTrace(); 
            } 
        } 
 
 
        // 下面測試 /data/data/com.test.db/databases/ 下的資料庫是否能正常工作  
        database = SQLiteDatabase.openOrCreateDatabase(DB_PATH + DB_NAME, null); 
        Cursor cursor = database.rawQuery("select * from wifi_private", null);//這句話沒通過  
         Log.v("111","111"); 
        if (cursor.getCount() > 0) { 
            cursor.moveToFirst(); 
            // 解決中文亂碼問題  
            String SSID = cursor.getString(cursor.getColumnIndex("SSID"));  
            //byte test[] = cursor.getBlob(0);  
            //String strtest = new String(test, "utf-8").trim();  
 
 
            // 看輸出的資訊是否正確  
            Log.v("SSID",""+SSID); 
        } 
        cursor.close(); 
         
        Log.v("222","222");  

String DB_PATH = "/data/data/com.example.mymap/databases/";
  String DB_NAME = "wifi.db";


  // 檢查 SQLite 資料庫檔案是否存在
  if ((new File(DB_PATH + DB_NAME)).exists() == false) {
   // 如 SQLite 資料庫檔案不存在,再檢查一下 database 目錄是否存在
   File f = new File(DB_PATH);
   // 如 database 目錄不存在,建立該目錄
   if (!f.exists()) {
    f.mkdir();
   }


   try {
    // 得到 assets 目錄下我們實現準備好的 SQLite 資料庫作為輸入資料流
    InputStream is = getBaseContext().getAssets().open(DB_NAME);
    // 輸出資料流
    OutputStream os = new FileOutputStream(DB_PATH + DB_NAME);


    // 檔案寫入
    byte[] buffer = new byte[1024];
    int length;
    while ((length = is.read(buffer)) > 0) {
     os.write(buffer, 0, length);
    }


    // 關閉檔案流
    os.flush();
    os.close();
    is.close();
   } catch (Exception e) {
    e.printStackTrace();
   }
  }


  // 下面測試 /data/data/com.test.db/databases/ 下的資料庫是否能正常工作
     database = SQLiteDatabase.openOrCreateDatabase(DB_PATH + DB_NAME, null);
  Cursor cursor = database.rawQuery("select * from wifi_private", null);//這句話沒通過
         Log.v("111","111");
  if (cursor.getCount() > 0) {
   cursor.moveToFirst();
   // 解決中文亂碼問題
   String SSID = cursor.getString(cursor.getColumnIndex("SSID"));
   //byte test[] = cursor.getBlob(0);
   //String strtest = new String(test, "utf-8").trim();


   // 看輸出的資訊是否正確
   Log.v("SSID",""+SSID);
  }
  cursor.close();
       
  Log.v("222","222");

 


這樣一來 資料庫就匯入成功了,需要注意的一點,該匯入進去的資料庫並不會和你程式中建立的資料庫產生衝突(只要資料庫名不同,表名相不相同無所謂),所以,有些資料是安裝程式的同時匯入,有些資料也可以在程式中根據使用者個人的操作進行添加,並不會產生衝突。


 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.