首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >nullPointerException at getWritableDatabase()

nullPointerException at getWritableDatabase()
EN

Stack Overflow用户
提问于 2013-07-07 18:22:17
回答 2查看 5.7K关注 0票数 1

新来的机器人。我已经开发了一个新的片段应用程序,而且我在从片段访问数据库时遇到了困难。

这是一堂课:

代码语言:javascript
复制
public class ShopListActivity extends FragmentActivity {
    SectionsPagerAdapter mSectionsPagerAdapter;
    ViewPager mViewPager;
    DatabaseHelper db;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_shoplist);

        db = new DatabaseHelper(this); // tried getApplicationContext(), and getBaseContext() as well

        mSectionsPagerAdapter = new SectionsPagerAdapter(getSupportFragmentManager());
        mViewPager = (ViewPager) findViewById(R.id.pager);
        mViewPager.setAdapter(mSectionsPagerAdapter);

    }

    public void onClickAddProduct(View view) {
        TextView productName = (TextView) findViewById(R.id.add_product_text);
        SQLiteDatabase dbWritable = db.getWritableDatabase(); // <-- crashes here

        ContentValues values = new ContentValues();
        values.put("Name", (String) productName.getText());

        dbWritable.insert("Lists", "Name", values);
    }

我在上面找到的所有其他解决方案都没有帮助。DatabaseHelper是一个非常基本的DB帮助类:

代码语言:javascript
复制
public DatabaseHelper(Context context) {
    super(context, dbName, null, dbVersion);
}

public void onCreate(SQLiteDatabase db) {
    db.execSQL(SQL_CREATE_TABLES);
    db.execSQL("INSERT INTO Lists (Name) VALUES('Test')");
}

这是逻辑猫:

代码语言:javascript
复制
07-07 21:03:24.351    9641-9641/com.chas.shopforme             E/AndroidRuntime: FATAL EXCEPTION: main
        java.lang.IllegalStateException: Could not execute method of the activity
        at android.view.View$1.onClick(View.java:3606)
        at android.view.View.performClick(View.java:4211)
        at android.view.View$PerformClick.run(View.java:17362)
        at android.os.Handler.handleCallback(Handler.java:725)
        at android.os.Handler.dispatchMessage(Handler.java:92)
        at android.os.Looper.loop(Looper.java:137)
        at android.app.ActivityThread.main(ActivityThread.java:5227)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:511)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562)
        at dalvik.system.NativeStart.main(Native Method)
        Caused by: java.lang.reflect.InvocationTargetException
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:511)
        at android.view.View$1.onClick(View.java:3601)
        ... 11 more
        Caused by: java.lang.NullPointerException
        at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:224)
        at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:164)
        at com.chas.shopforme.ShopListActivity.onClickAddProduct(ShopListActivity.java:69)
        ... 14 more

注意:我知道还有更多这样的问题,但他们的解决方案对我来说行不通。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-07-08 02:08:53

尝尝这个

代码语言:javascript
复制
db = new DatabaseHelper(this.getApplicationContext()); 
票数 2
EN

Stack Overflow用户

发布于 2013-07-09 09:37:35

我试着在你的问题中添加这个注释,但是在注释中出现了一些讨厌的事情。

假设您已经在上面的注释中尝试过( a),但它没有工作,那么下面是b的一个例子:

代码语言:javascript
复制
protected void onCreate(Bundle savedInstanceState) {

...

    Handler hand = new Handler();
    hand.post(new Runnable() {
        public void run() {
            dbInit();
        }
    });
}

public void dbInit() {
    db = new DatabaseHelper(this);
}

这允许碎片管理器在尝试使用片段之前完成对它的设置。它所做的是向自己发送一条消息,当片段的消息处理程序循环运行时,该消息将被处理。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17514933

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档