你好,欢迎来到电脑编程技巧与维护杂志社! 杂志社简介广告服务读者反馈编程社区  
合订本订阅
 
 
您的位置:技术专栏 / 数据库开发
android开发中,导入有数据的sqlite,与apk一起安装到手机上
 

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");

 


这样一来 数据库就导入成功了,需要注意的一点,该导入进去的数据库并不会和你程序中创建的数据库产生冲突(只要数据库名不同,表名相不相同无所谓),所以,有些数据是安装程序的同时导入,有些数据也可以在程序中根据用户个人的操作进行添加,并不会产生冲突。

  推荐精品文章

·2024年12月目录 
·2024年11月目录 
·2024年10月目录 
·2024年9月目录 
·2024年8月目录 
·2024年7月目录 
·2024年6月目录 
·2024年5月目录 
·2024年4月目录 
·2024年3月目录 
·2024年2月目录 
·2024年1月目录
·2023年12月目录
·2023年11月目录

  联系方式
TEL:010-82561037
Fax: 010-82561614
QQ: 100164630
Mail:gaojian@comprg.com.cn

  友情链接
 
Copyright 2001-2010, www.comprg.com.cn, All Rights Reserved
京ICP备14022230号-1,电话/传真:010-82561037 82561614 ,Mail:gaojian@comprg.com.cn
地址:北京市海淀区远大路20号宝蓝大厦E座704,邮编:100089