在android中创建数据库文件

在android中创建数据库文件,android,android-sqlite,Android,Android Sqlite,默认情况下,在应用程序数据中创建应用程序的数据库文件。是否可以在我们自己的路径中创建数据库文件,如“/mnt/sdcard/test.db” 我通过扩展SQLiteOpenhelper来创建数据库文件,但它创建的是应用程序内的数据位置。我想在SD卡位置创建。我尝试使用“db.OpenorCreateDatabase(Path)”。 它在那个位置创建了一个db文件,当我试图读取该文件时,它崩溃了。怎么做?如果您提供了一个自定义ContextClass,并且在目标目录中有写访问权限,您可以使用带有自

默认情况下,在应用程序数据中创建应用程序的数据库文件。是否可以在我们自己的路径中创建数据库文件,如“/mnt/sdcard/test.db”

我通过扩展SQLiteOpenhelper来创建数据库文件,但它创建的是应用程序内的数据位置。我想在SD卡位置创建。我尝试使用“db.OpenorCreateDatabase(Path)”。
它在那个位置创建了一个db文件,当我试图读取该文件时,它崩溃了。怎么做?

如果您提供了一个自定义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;
}
}

这很旧,但对于那些希望将数据库放置在可访问目录中进行调试的人来说,最简单的方法是:

在dbHelper构造函数中,将替代路径添加到db名称:

  private DbHelper(Context context)
{
    super(context, "/mnt/sdcard/"+DATABASE_NAME, null, DATABASE_VERSION);
}
并记住添加权限:

    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

是的,但它不安全,因为SD卡可以被其他应用程序访问。你能详细说明一下“它正在崩溃”吗?