2013-07-07 2 views
1

Новое для Android здесь. Я создал новое приложение Fragments, и у меня возникли проблемы с доступом к базе данных из фрагмента.nullPointerException at getWritableDatabase()

Вот класс:

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); 
    } 

Все другие решения, которые я нашел на SO не помогло. DatabaseHelper очень простой DB Вспомогательный класс:

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')"); 
} 

Вот Logcat:

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 

Примечание: Я знаю, что есть еще вопросы, как это, но их решения не работает для меня ,

+1

В соответствии с исходным кодом для Android (https://github.com/android/platform_frameworks_base/blob/master/core/java/android/database/sqlite/SQLiteOpenHelper.java), android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked (SQLiteOpenHelper.java:224). Строка 224 - это доступ к контексту, и для вашего приложения это ошибка. Я не могу думать, что делает контекст в DbHelper равным нулю. –

+0

Похоже, что фрагмент еще не был полностью привязан к действию, поэтому могут возникнуть проблемы с использованием «этого». Несколько вещей, чтобы попробовать: а) переместить вспомогательный init в onResume и закрыть его в onPause. б) использовать обработчик сообщений для задержки создания помощника db через почту. b немного взломан. –

+0

b. является waayyyy вне моего понимания. Поговорите со мной, как n00b: ') – casraf

ответ

2

попробовать этот

db = new DatabaseHelper(this.getApplicationContext()); 
+0

Какой-то прогресс; сбой в том же месте, но с 'InvocationTargetException' – casraf

+0

Решил это - это исключение было потому, что я выбрал' (String) productName.getText() 'вместо' productName.getText(). toString() ' – casraf

1

Я попытался добавить это в качестве комментария к вашему вопросу, но неприятные вещи случаются закодировать в комментариях.

Предполагая, что вы уже пробовали) в комментарии выше, и это не сработало, пример б) следующим образом:

protected void onCreate(Bundle savedInstanceState) { 

... 

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

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

Это позволяет менеджеру фрагмент, чтобы завершить установку фрагмента перед вами попробуйте использовать его. То, что он делает, отправляет сообщение самому себе, которое обрабатывается, когда выполняется цикл обработчика сообщения фрагмента.

+0

Ну, я получаю 'java.lang.reflect.InvocationTargetException' exception ... Поэтому я предполагаю, что решение позволит мне использовать более простое решение, например, @ soynerdito's – casraf

+0

Я получил решение, ошибка Invocation приведет меня к другой проблеме синтаксиса; и, как я уже сказал, более простое решение другого ответа было лучше для меня, так как я не хотел делать это слишком сложным. Тем не менее, спасибо! – casraf