默认情况下,应用程序的数据库文件在应用程序数据中创建。是否可以在我们自己的路径中创建数据库文件,如“/mnt/sdcard/test.db”?
我通过扩展SQLiteOpenhelper来创建数据库文件,但是它在app数据位置创建。我想在SD卡位置创建。我试过“db.OpenorCreateDatabase(Path)”。 它在那个位置创建一个db文件,当我试图读取该文件时它崩溃了。怎么做?
答案 0 :(得分:3)
如果您提供自定义ContextClass并且您在目标目录中具有写访问权限,则可以将SQLiteOpenHelper与自定义路径一起使用(至少使用android 2.2)。
public class DatabaseHelper extends SQLiteOpenHelper {
private static final int DATABASE_VERSION = 3;
.....
DatabaseHelper(final Context context, String databaseName)
{
super(new DatabaseContext(context), databaseName, null, DATABASE_VERSION);
}
}
这是自定义DatabaseContext类,可以完成所有魔法
class DatabaseContext extends ContextWrapper {
private static final String DEBUG_CONTEXT = "DatabaseContext";
public DatabaseContext(Context base) {
super(base);
}
@Override
public File getDatabasePath(String name)
{
File sdcard = Environment.getExternalStorageDirectory();
String dbfile = sdcard.getAbsolutePath() + File.separator+ "databases" + File.separator + name;
if (!dbfile.endsWith(".db"))
{
dbfile += ".db" ;
}
File result = new File(dbfile);
if (!result.getParentFile().exists())
{
result.getParentFile().mkdirs();
}
if (Log.isLoggable(DEBUG_CONTEXT, Log.WARN))
{
Log.w(DEBUG_CONTEXT,
"getDatabasePath(" + name + ") = " + result.getAbsolutePath());
}
return result;
}
@Override
public SQLiteDatabase openOrCreateDatabase(String name, int mode, SQLiteDatabase.CursorFactory factory)
{
SQLiteDatabase result = SQLiteDatabase.openOrCreateDatabase(getDatabasePath(name), null);
// SQLiteDatabase result = super.openOrCreateDatabase(name, mode, factory);
if (Log.isLoggable(DEBUG_CONTEXT, Log.WARN))
{
Log.w(DEBUG_CONTEXT,
"openOrCreateDatabase(" + name + ",,) = " + result.getPath());
}
return result;
}
}
答案 1 :(得分:0)
这是旧的,但是对于那些寻找将数据库放在可访问目录中以进行调试的人来说,这是最简单的方法:
在dbHelper构造函数中,添加数据库名称的替代路径:
private DbHelper(Context context)
{
super(context, "/mnt/sdcard/"+DATABASE_NAME, null, DATABASE_VERSION);
}
并记住添加权限:
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />