gpt4 book ai didi

Android SQLite - openOrCreateDatabase() nullPointerException

转载 作者:太空狗 更新时间:2023-10-29 15:56:29 26 4
gpt4 key购买 nike

我有以下 DBAdapter(这不是全部,但它是相关代码)。

private final String DATABASE_NAME = "seller";
private final String DATABASE_MY_TABLE = "sellertable";
private final Integer DATABASE_VERSION = 1
private final String CREATE_TABLE = "CREATE TABLE seller ........";

public DBAdapter( Context c )
{
this.context = c;
DBHelper = new DatabaseHelper(context);
}

private static class DatabaseHelper extends SQLiteOpenHelper
{
public DatabaseHelper( Context context )
{
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}

@Override
public void onCreate( SQLiteDatabase db )
{
MyLog.d("Creating Tables");
try
{
db.execSQL(CREATE_TABLE);
}
catch (Exception e)
{
e.printStackTrace();
}
}

@Override
public void onUpgrade( SQLiteDatabase db, int oldVersion, int newVersion )
{
MyLog.w("Upgrading database from version " + oldVersion + " to " + newVersion + ". Destroying old data.");
db.execSQL("DROP TABLE IF EXISTS " + DATABASE_MY_TABLE);
onCreate(db);
}
}

// Opens the database
public DBAdapter open() throws SQLException
{
db = DBHelper.getWritableDatabase();
return this;
}

当我尝试 db.open() 时,我得到以下信息:

FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to instantiate application com.company.app.MyApp: java.lang.NullPointerException
at android.app.LoadedApk.makeApplication(LoadedApk.java:466)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:3260)
at android.app.ActivityThread.access$2200(ActivityThread.java:117)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:969)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:130)
at android.app.ActivityThread.main(ActivityThread.java:3683)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:507)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:203)
at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:118)
at com.company.app.DBAdapter.open(DBAdapter.java:74)
at com.company.app.MyApp.<init>(MyApp.java:106)
at java.lang.Class.newInstanceImpl(Native Method)
at java.lang.Class.newInstance(Class.java:1409)
at android.app.Instrumentation.newApplication(Instrumentation.java:957)
at android.app.Instrumentation.newApplication(Instrumentation.java:942)
at android.app.LoadedApk.makeApplication(LoadedApk.java:461)

它似乎遇到了某种异常,与助手决定是否创建或更新数据库的时间有关...

最佳答案

我刚遇到这个,可能是出于不同的原因。在调用 onCreate() 之前,我尝试做一些涉及上下文的与数据库相关的事情。希望这可以帮助那里的人

关于Android SQLite - openOrCreateDatabase() nullPointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7957991/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com