私はAndroidで非常に確実にコーディングしようとしているので、dbとの接続用の別のクラス、テーブルの作成、挿入更新と削除用のクラスなど、さまざまな目的のためにさまざまなクラスを作成しました。現在、SQLiteDatabase [mDb] で問題が発生しています。テーブル列、つまり recipient.class のゲッターとセッターがあるクラスがありました。ここで、データベースにデータを挿入する必要があるため、挿入のために次のようにしました。
public long insert(Recipient recipient, String[] images){
ContentValues initialValues = new ContentValues();
initialValues.put(FLD_RECIPIENT_ID, Recipient.getFldRecipientId());
initialValues.put(FLD_INFO, Recipient.getFldInfo());
initialValues.put(FLD_LATITUDE, Recipient.getFldLatitude());
initialValues.put(FLD_LONGITUDE, Recipient.getFldLongitude());
for(int i=0;i<images.length;i++){
if(images[i]!=null){
initialValues.put("FLD_IMAGE_URL"+(i+1), images[i]);
}
}
return mDb.insert(DATABASE_TABLE, null, initialValues);
}
デバッグすると、initialValues のすべての値が設定され、mDb.insert が実行されると終了し、nullPointException と mDb null の値が表示されます。なぜそうなのか理解できません.SO誰かが私を助けることができれば??? また、mDb を次のように初期化しました。
private SQLiteDatabase mDb;
ログキャット:
01-01 11:11:27.963: E/AndroidRuntime(992): FATAL EXCEPTION: main
01-01 11:11:27.963: E/AndroidRuntime(992): java.lang.NullPointerException
01-01 11:11:27.963: E/AndroidRuntime(992): at com.example.android.photobyintent.DbReceipient.insert(DbReceipient.java:43)
01-01 11:11:27.963: E/AndroidRuntime(992): at com.example.android.photobyintent.AddRecipient.insertIntoDb(AddRecipient.java:451)
01-01 11:11:27.963: E/AndroidRuntime(992): at com.example.android.photobyintent.AddRecipient$4.onClick(AddRecipient.java:409)
01-01 11:11:27.963: E/AndroidRuntime(992): at android.view.View.performClick(View.java:4202)
01-01 11:11:27.963: E/AndroidRuntime(992): at android.view.View$PerformClick.run(View.java:17340)
01-01 11:11:27.963: E/AndroidRuntime(992): at android.os.Handler.handleCallback(Handler.java:725)
01-01 11:11:27.963: E/AndroidRuntime(992): at android.os.Handler.dispatchMessage(Handler.java:92)
01-01 11:11:27.963: E/AndroidRuntime(992): at android.os.Looper.loop(Looper.java:137)
01-01 11:11:27.963: E/AndroidRuntime(992): at android.app.ActivityThread.main(ActivityThread.java:5039)
01-01 11:11:27.963: E/AndroidRuntime(992): at java.lang.reflect.Method.invokeNative(Native Method)
01-01 11:11:27.963: E/AndroidRuntime(992): at java.lang.reflect.Method.invoke(Method.java:511)
01-01 11:11:27.963: E/AndroidRuntime(992): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
01-01 11:11:27.963: E/AndroidRuntime(992): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
01-01 11:11:27.963: E/AndroidRuntime(992): at dalvik.system.NativeStart.main(Native Method)