Android 使用存放在存assets文件夹下的SQLite数据库
因为这次的项目需要自带数据,所以就就把数据都放到一个SQLite的数据库文件中了,之后把该文件放到了assets文件夹下面。一开始打算每次都从assets文件夹下面把该文件夹拷贝到手机的SD卡或者手机自身的存储上之后再使用,后来考虑到每次都拷贝的话效率不高,并且如果涉及到对数据库的修改操作的话拷贝之后数据就被恢复了。
因此就写了该封装,该封装只是在第一次使用数据库文件的时候把该文件夹拷贝到手机的/data/data/应用程序报名/database文件夹下,之后就直接从这个地方使用了。并且它允许你直接通过assets文件夹下的数据库名称来获取SQLiteDatabase对象,这样就极大的方便了你对数据库的使用。
- package com.jemsn.database;
- import java.io.File;
- import java.io.FileOutputStream;
- import java.io.InputStream;
- import java.io.OutputStream;
- import java.util.HashMap;
- import java.util.Map;
- import android.content.Context;
- import android.content.SharedPreferences;
- import android.content.res.AssetManager;
- import android.database.sqlite.SQLiteDatabase;
- import android.util.Log;
- /**
- * This is a Assets Database Manager
- * Use it, you can use a assets database file in you application
- * It will copy the database file to "/data/data/[your application package name]/database" when you first time you use it
- * Then you can get a SQLiteDatabase object by the assets database file
- * @author RobinTang
- * @time 2012-09-20
- *
- *
- * How to use:
- * 1. Initialize AssetsDatabaseManager
- * 2. Get AssetsDatabaseManager
- * 3. Get a SQLiteDatabase object through database file
- * 4. Use this database object
- *
- * Using example:
- * AssetsDatabaseManager.initManager(getApplication()); // this method is only need call one time
- * AssetsDatabaseManager mg = AssetsDatabaseManager.getManager(); // get a AssetsDatabaseManager object
- * SQLiteDatabase db1 = mg.getDatabase("db1.db"); // get SQLiteDatabase object, db1.db is a file in assets folder
- * db1.??? // every operate by you want
- * Of cause, you can use AssetsDatabaseManager.getManager().getDatabase("xx") to get a database when you need use a database
- */
- public class AssetsDatabaseManager {
- private static String tag = "AssetsDatabase"; // for LogCat
- private static String databasepath = "/data/data/%s/database"; // %s is packageName
- // A mapping from assets database file to SQLiteDatabase object
- private Map<String, SQLiteDatabase> databases = new HashMap<String, SQLiteDatabase>();
- // Context of application
- private Context context = null;
- // Singleton Pattern
- private static AssetsDatabaseManager mInstance = null;
- /**
- * Initialize AssetsDatabaseManager
- * @param context, context of application
- */
- public static void initManager(Context context){
- if(mInstance == null){
- mInstance = new AssetsDatabaseManager(context);
- }
- }
- /**
- * Get a AssetsDatabaseManager object
- * @return, if success return a AssetsDatabaseManager object, else return null
- */
- public static AssetsDatabaseManager getManager(){
- return mInstance;
- }
- private AssetsDatabaseManager(Context context){
- this.context = context;
- }
- /**
- * Get a assets database, if this database is opened this method is only return a copy of the opened database
- * @param dbfile, the assets file which will be opened for a database
- * @return, if success it return a SQLiteDatabase object else return null
- */
- public SQLiteDatabase getDatabase(String dbfile) {
- if(databases.get(dbfile) != null){
- Log.i(tag, String.format("Return a database copy of %s", dbfile));
- return (SQLiteDatabase) databases.get(dbfile);
- }
- if(context==null)
- return null;
- Log.i(tag, String.format("Create database %s", dbfile));
- String spath = getDatabaseFilepath();
- String sfile = getDatabaseFile(dbfile);
- File file = new File(sfile);
- SharedPreferences dbs = context.getSharedPreferences(AssetsDatabaseManager.class.toString(), 0);
- boolean flag = dbs.getBoolean(dbfile, false); // Get Database file flag, if true means this database file was copied and valid
- if(!flag || !file.exists()){
- file = new File(spath);
- if(!file.exists() && !file.mkdirs()){
- Log.i(tag, "Create \""+spath+"\" fail!");
- return null;
- }
- if(!copyAssetsToFilesystem(dbfile, sfile)){
- Log.i(tag, String.format("Copy %s to %s fail!", dbfile, sfile));
- return null;
- }
- dbs.edit().putBoolean(dbfile, true).commit();
- }
- SQLiteDatabase db = SQLiteDatabase.openDatabase(sfile, null, SQLiteDatabase.NO_LOCALIZED_COLLATORS);
- if(db != null){
- databases.put(dbfile, db);
- }
- return db;
- }
- private String getDatabaseFilepath(){
- return String.format(databasepath, context.getApplicationInfo().packageName);
- }
- private String getDatabaseFile(String dbfile){
- return getDatabaseFilepath()+"/"+dbfile;
- }
- private boolean copyAssetsToFilesystem(String assetsSrc, String des){
- Log.i(tag, "Copy "+assetsSrc+" to "+des);
- InputStream istream = null;
- OutputStream ostream = null;
- try{
- AssetManager am = context.getAssets();
- istream = am.open(assetsSrc);
- ostream = new FileOutputStream(des);
- byte[] buffer = new byte[1024];
- int length;
- while ((length = istream.read(buffer))>0){
- ostream.write(buffer, 0, length);
- }
- istream.close();
- ostream.close();
- }
- catch(Exception e){
- e.printStackTrace();
- try{
- if(istream!=null)
- istream.close();
- if(ostream!=null)
- ostream.close();
- }
- catch(Exception ee){
- ee.printStackTrace();
- }
- return false;
- }
- return true;
- }
- /**
- * Close assets database
- * @param dbfile, the assets file which will be closed soon
- * @return, the status of this operating
- */
- public boolean closeDatabase(String dbfile){
- if(databases.get(dbfile) != null){
- SQLiteDatabase db = (SQLiteDatabase) databases.get(dbfile);
- db.close();
- databases.remove(dbfile);
- return true;
- }
- return false;
- }
- /**
- * Close all assets database
- */
- static public void closeAllDatabase(){
- Log.i(tag, "closeAllDatabase");
- if(mInstance != null){
- for(int i=0; i<mInstance.databases.size(); ++i){
- if(mInstance.databases.get(i)!=null){
- mInstance.databases.get(i).close();
- }
- }
- mInstance.databases.clear();
- }
- }
- }
使用的过程也很简单,应用程序开始的时候初始化一下,之后就可以在任意地方获取管理器在通过assets文件夹下的数据库文件名直接获取SQLiteDatabase对象,之后对数据库的操作就完全看你了。。。
简单的使用例子:
- // 初始化,只需要调用一次
- AssetsDatabaseManager.initManager(getApplication());
- // 获取管理对象,因为数据库需要通过管理对象才能够获取
- AssetsDatabaseManager mg = AssetsDatabaseManager.getManager();
- // 通过管理对象获取数据库
- SQLiteDatabase db1 = mg.getDatabase("db1.db");
- // 对数据库进行操作
- db1.execSQL("insert into tb([ID],[content]) values(null, 'db1');");
需要注意的是获取数据库对象的时候是区分数据库文件名的大小写的。
Android 使用存放在存assets文件夹下的SQLite数据库的更多相关文章
- 42、使用存放在存assets文件夹下的SQLite数据库
因为这次的项目需要自带数据,所以就就把数据都放到一个SQLite的数据库文件中了,之后把该文件放到了assets文件夹下面.一开始打算每次都从assets文件夹下面把该文件夹拷贝到手机的SD卡或者手机 ...
- Android开发系列(十七):读取assets文件夹下的数据库文件
在做Android应用的时候,不可避免要用到数据库.可是当我们把应用的apk部署到真机上的时候,已经创建好的数据库及其里边的数据是不能随着apk一起安装到真机上的. (PS:这篇博客攻克了我前面博客中 ...
- 读取assets文件夹下图片(ods_interview)
今天看了一道题,现在总结一下里面使用到的知识点: 1.assets文件的访问: 原文出处:http://blog.csdn.net/fengyuzhengfan/article/details/383 ...
- Android程序函数 将assets文件夹下的文件复制到手机的sd卡中(包括子文件夹)
最近在做个功能是将asset文件夹下的所有文件(包括子文件)全部拷贝出来到指定目录下.所用的方法无非是用AssetManager.但是这里 有个问题是也要讲子文件夹和子文件都要拷贝出来.到网上Goog ...
- Android开发:第四日番外——Assets文件夹和RAW文件夹区别
话说上回说到SQLite数据库,其中涉及到把已经设计好的数据库打包到APK中,提到可以放置在Assert文件夹或者RAW文件夹中,那么两者到底有什么区别呢?让我们来探究一下. 一.res/raw和as ...
- android assets文件夹浅谈
---恢复内容开始--- 最近在研究assets文件夹的一些属性跟使用方法.根据网上一些文章.实例做一下汇总,拿出来跟大家分享下,有不足的地方还请多多指教. 首先了解一下assets是干什么用的,as ...
- Android编程心得-在Assets文件夹中放入.sql文件实现创建SQlite表的操作
当我们在使用SQLiteOpenHelper时,经常使用db.execSQL(String sql)方法写入对应语句实现创建表的操作,这样的确可以实现业务逻辑.与此同时还有一种更灵活的方法,从asse ...
- Unity 需不需要再建Assets文件夹
不需要,默认所有文件都是在Assets文件夹下创建的,看不到是因为设置了单栏模式,开启双栏模式就能看到了.
- Android assets文件夹之位置放置和作用
Android 的assets文件夹的放置位置,Eclipse创建项目时就生成了的,Android Studio则不太一样,AS可以包含几种方式, 1:可以在build.gradle文件下配置,加如下 ...
随机推荐
- 七牛 在线管理 v0.1
<?php // @codingStandardsIgnoreFile require_once __DIR__.'/../vendor/autoload.php'; use Qiniu\Aut ...
- HttpServletRequest对象(一)
一:HttpServletRequest介绍: 代表客户端的请求,当客户端通过HTTP协议访问服务器时,HTTP请求头中的所有信息都封装在这个对象中, 二:Request常用的方法 1):获得客户端信 ...
- Java判断PC端还是移动端
package com.*.*.*; import java.io.IOException;import java.util.regex.Matcher;import java.util.regex. ...
- Confluence搭建
参见 https://confluence.atlassian.com/display/CONF54/Installing+the+Confluence+EAR-WAR+Edition 下载5.4.4 ...
- MySql 安装报错 :Last Error:Unable to update security. Access denied for user 'root'@'localhost(useing password:YES)
在网上查了一下,其实这个问题很好解决,. try again 然后current password mysql是默认密码为空,不要填,记住不要填就ok了
- SELinux Policy Macros
参考:http://selinuxproject.org/page/NB_RefPolicy Directory Macros macro expansion getattr_dir_perms ge ...
- ==、equals、hashCode区别?
[==.equals().hashCode()区别?] 1)== 运算符用来比较两个变量的值是否相等. 即该运算符用于比较变量对应得内存中所存储的数值是否相同,要比较两个基本类型的数据或两个引用变量是 ...
- FTP、TFTP
FTP 文件传送协议 (File Transfer Protocol) FTP是因特网上使用得最广泛的文件传送协议. 文件传送协议 FTP (File Transfer Protocol) 是因 ...
- 学习笔记——迭代器模式Iterator
迭代器模式,使用很多,但是很少实现.常用的集合都支持迭代器. 集合中的CreateIterator()可用于创建自己的迭代器,在里面通过调用迭代器的构造函数Iterator(Aggregate)来绑定 ...
- Java Queue 各种方法的区别
再Java里的某些集合类,其实是实现了多个接口的,所以就会同时又多种方法针对同一种操作,比如LinkedList类. 首先看一下java集合类的继承关系图: 这里简单对其重复的方法做点简单的区分. o ...