创建数据库的时候就将数据库保存到SDcard中
来源:互联网 发布:资本在线网络贷款 编辑:程序博客网 时间:2024/06/11 17:34
这几天在做项目demo时有个自带的数据库保存默认路径下,每当卸载程序的时候数据也会跟着被删除,所以网上一直在找关于数据库保存到指定路径下的,这也让数据不会被删除。当下次安装的时候还能使用该数据。
以下为自己网上找的,然后下载其demo运行了一下,看了一下数据发现能存在指定文件路径下。所以我在这直接将SDSQLiteOpenHelper这个类复制到了我项目上,然后让MyDatabaseHelper直接继承SDSQLiteOpenHelper这个类,最后将继承得到的方法里边相应的值写上方可。
---------------------------------------------以下为网上找的例子-------------------------------------------------------------------------------------
http://www.eoeandroid.com/forum.php?mod=viewthread&tid=53985&extra=page%3D1&page=1
我们知道数据库创建的时候默认保存到系统data/data/项目名 下面了,有没有一种方法保存到自己指定的SDCard上的文件夹里面呢?答案是可以的。我们只需要找到SQLiteOpenHelper这个类,了解一下就不难发现其保存的路径是固定了的,那么我们只需要改动一下getWritableDatabase(),即写入的时候的路径:
public synchronized SQLiteDatabase getWritableDatabase() {if (mDatabase != null && mDatabase.isOpen() && !mDatabase.isReadOnly()) {
return mDatabase; // The database is already open for business
}
if (mIsInitializing) {
throw new IllegalStateException("getWritableDatabase called recursively");
}
// If we have a read-only database open, someone could be using it
// (though they shouldn't), which would cause a lock to be held on
// the file, and our attempts to open the database read-write would
// fail waiting for the file lock. To prevent that, we acquire the
// lock on the read-only database, which shuts out other users.
boolean success = false;
SQLiteDatabase db = null;
if (mDatabase != null) mDatabase.lock();
try {
mIsInitializing = true;
if (mName == null) {
db = SQLiteDatabase.create(null);
} else {
db = mContext.openOrCreateDatabase(mName, 0, mFactory);
}
int version = db.getVersion();
if (version != mNewVersion) {
db.beginTransaction();
try {
if (version == 0) {
onCreate(db);
} else {
onUpgrade(db, version, mNewVersion);
}
db.setVersion(mNewVersion);
db.setTransactionSuccessful();
} finally {
db.endTransaction();
}
}
onOpen(db);
success = true;
return db;
} finally {
mIsInitializing = false;
if (success) {
if (mDatabase != null) {
try { mDatabase.close(); } catch (Exception e) { }
mDatabase.unlock();
}
mDatabase = db;
} else {
if (mDatabase != null) mDatabase.unlock();
if (db != null) db.close();
}
}
}
注意标志的红色的部分,这是创建数据库的地方,我们再看看openOrCreateDatabase()
这个方法,openOrCreateDatabase()这个方法存在于package android.content;下面的public abstract class Context{}类里面,
public abstract SQLiteDatabase openOrCreateDatabase(String name,int mode, CursorFactory factory);
我们发现在package android.database.sqlite;包下的public class SQLiteDatabase extends SQLiteClosable {}里面也有一个
public static SQLiteDatabase openOrCreateDatabase(String path, CursorFactory factory) {
return openDatabase(path, factory, CREATE_IF_NECESSARY);
}
相同的方法,只是参数不同,这个可以传一个路径进去,我们就调用这个方法。
然后我们还要有一个我们指定文件夹的路径的方法:
public File getDatabasePath(String name) {
String EXTERN_PATH = null;
//判断是否有SDcard
if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)==true)
{
//判断是否存在指定的文件夹,如果没有就创建它
EXTERN_PATH = android.os.Environment.getExternalStorageDirectory().getAbsolutePath()
+ "/database/";
File f=new File(EXTERN_PATH);
if(!f.exists())
{
f.mkdirs();
}
}
return new File(EXTERN_PATH+ name);
}
及对SDcard进行写和读的权限:
<!-- 在SDCard中创建于删除文件权限 -->
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />
<!-- 往SDCard写入数据权限 -->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
最后当我们创建数据库的时候直接继承我们自己定义的SDSQLiteOpenHelper(),不用系统自带SQLiteOpenHelper()即可。
最后贴上例子: Test.zip
阅读全文
0 0
- 创建数据库的时候就将数据库保存到SDcard中
- 创建数据库的时候就将数据库保存到SDcard中
- 数据库保存到SDcard
- Android--将数据保存到SDCard中
- Android--将数据保存到SDCard中
- 将文件保存到sdCard中去
- 将文件保存到数据库中
- 将文件保存到数据库中(stream)
- 将图片保存到数据库中
- C#将文件保存到数据库中
- 将文件保存到数据库中
- 将文件保存到数据库中
- 将图片保存到SQL数据库中
- 将文件保存到数据库中
- 将数据库中表的数据保存到XML文件中
- 将图片保存到数据库的处理
- 将bitmap保存到sdcard
- php将图片保存到mysql数据库及从数据库中读取图片的方法源码
- 嵌入式学习10(C语言五大内存区间,变量的作用域和生存期,变量的存储类型)
- IDEA部分快捷键 git文件过滤以及其他杂文
- 压缩多张图片,解压后发现图片文件损坏的问题解决
- POJ 1724 ROADS (DFS)
- 0717学习总结(c++模板)
- 创建数据库的时候就将数据库保存到SDcard中
- 第2节-Linux的硬盘分区格式
- 连马云都要打包带走的美食_你不来一份儿?
- ORACLE RAC 集群的启动和关闭
- dubbo java.lang.NoClassDefFoundError
- 数对之差的最大值
- 互联网应用架构师
- Why would I want to fitsSystemWindows?
- vb.net 如何在同一页面,添加相同的usercontrol