【问题标题】:Problem with sqlite database on android platformandroid平台上sqlite数据库的问题
【发布时间】:2010-03-19 04:39:11
【问题描述】:

我正在开发一个使用 sqlite db 来存储记录的应用程序。我正在 SDK 1.5 上开发此应用程序。当我在 1.5 设备上测试应用程序时,它运行良好,但是当我尝试在 1.6 设备上运行它时,我收到一条带有以下 logcat 输出的强制关闭消息:

03-19 09:31:35.206:错误/AndroidRuntime(224):未捕获的处理程序:线程主因未捕获的异常而退出

03-19 09:31:35.226: 错误/AndroidRuntime(224): java.lang.RuntimeException: 无法启动活动 ComponentInfo{com.abc.android/com.abc.android.app}: android.database。 sqlite.SQLiteException: 无法打开数据库文件

03-19 09:31:35.226:错误/AndroidRuntime(224):在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2454)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2470)

03-19 09:31:35.226: ERROR/AndroidRuntime(224): at android.app.ActivityThread.access$2200(ActivityThread.java:119)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1821)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 android.os.Handler.dispatchMessage(Handler.java:99)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 android.os.Looper.loop(Looper.java:123)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 android.app.ActivityThread.main(ActivityThread.java:4310)

03-19 09:31:35.226: ERROR/AndroidRuntime(224): at java.lang.reflect.Method.invokeNative(Native Method)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 java.lang.reflect.Method.invoke(Method.java:521) 03-19 09:31:35.226: 错误/AndroidRuntime(224): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)

03-19 09:31:35.226: ERROR/AndroidRuntime(224): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)

03-19 09:31:35.226: ERROR/AndroidRuntime(224): at dalvik.system.NativeStart.main(Native Method)

03-19 09:31:35.226: ERROR/AndroidRuntime(224): Caused by: android.database.sqlite.SQLiteException: 无法打开数据库文件

03-19 09:31:35.226: ERROR/AndroidRuntime(224): at android.database.sqlite.SQLiteDatabase.dbopen(Native Method)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 android.database.sqlite.SQLiteDatabase.(SQLiteDatabase.java:1697)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:738)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 android.database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:760)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 android.database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:753)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 android.app.ApplicationContext.openOrCreateDatabase(ApplicationContext.java:473)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:193)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:98)

03-19 09:31:35.226:错误/AndroidRuntime(224):在 com.abc.android.DbAdapter.open(DbAdapter.java:101)

03-19 09:31:35.226:错误/AndroidRuntime(224):在 com.abc.android.class1.onCreate(class1.java:105)

03-19 09:31:35.226: 错误/AndroidRuntime(224): 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)

03-19 09:31:35.226:错误/AndroidRuntime(224):在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2417)

03-19 09:31:35.226: 错误/AndroidRuntime(224): ... 11 更多

DBAdapter.java

public DbAdapter open() throws SQLException {

        Log.d("DbAdapter", "in DbAdapter open()");

        mDbHelper = new DatabaseHelper(mCtx);
        mDb = mDbHelper.getWritableDatabase();        // line 101
        return this;
    }

 DatabaseHelper(Context context) {
 super(context, DATABASE_NAME, null, DATABASE_VERSION); 
 }

 @Override
 public void onCreate(SQLiteDatabase db) {
    db.execSQL(DATABASE_QUERY);
 }              

class1.java

mDB = new DbAdapter(Class1.this);
mDB.open();             // line 105

请帮忙..我该怎么办????

【问题讨论】:

  • 出于好奇,您是在之后关闭连接吗?
  • 为什么在你的DBAdapter.java类里面有一个浮动的DatabaseHelper构造函数?
  • 您确定在 DBAdapter 的第 101 行运行时数据库已创建并存在吗?这个android.database.sqlite.SQLiteException: unable to open database file 可能意味着它还没有被创建..

标签: android sqlite


【解决方案1】:

确保DATABASE_NAME 包含的值只是一个文件名,仅此而已,没有斜线等。

像这样: final String DATABASE_NAME = "mydata.db";

如果看起来不错,请从手机应用程序菜单中卸载您的应用程序,然后重新安装。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2017-10-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-05-06
    • 1970-01-01
    相关资源
    最近更新 更多