0

我正在尝试在 android 中进行更可靠的编码,因此我为不同的目的制作了不同的类,例如用于与 db 连接的单独类、创建表以及用于插入更新和删除的类。现在我遇到了 SQLiteDatabase [mDb] 的问题:我有一个类,其中有表列的 getter 和 setter,即接收者.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 的值。我不明白为什么会这样。所以如果有人可以帮助我???我还将 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)
4

5 回答 5

0

在 mDB 上执行此操作。

private SQLiteDatabase mDb = this.getWritableDatabase();
于 2013-01-01T10:57:31.267 回答
0

mDb在插入数据库之前初始化为:

public long insert(Recipient recipient, String[] images){
         mDb = Your_sqLiteHelper.getWritableDatabase();

         // your code here

        return mDb.insert(DATABASE_TABLE, null, initialValues);
    }
于 2013-01-01T10:59:03.343 回答
0

我认为 mDb 在您访问它之前未初始化或其为空。尝试:

在函数 mDb = this.getWritableDatabase() 之前;

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]);
        }
    }
     if(mdb!=null){
         return mDb.insert(DATABASE_TABLE, null, initialValues);
     }else {
         return null;
     }
}

如果返回值为 null 则相应地工作。

于 2013-01-01T11:00:22.437 回答
0

最好以原子方式使用数据库对象,在需要时打开它,在不再需要时立即关闭它

试试这样:

SQLiteDatabase db = opener.getWritableDatabase();

    try {
        ContentValues values = new ContentValues();
        /* set values */

        return db.insertOrThrow(tableName, null, values);
    } finally {
        db.close();
    }
于 2013-01-01T11:00:53.140 回答
0

看起来您的成员变量在您调用该方法时mDb尚未初始化(即它仍然是)。nullinsert

这个变量在你的班级哪里分配?也许您创建了另一个方法,命名为connect,您之前忘记调用了insert

在我提供任何进一步帮助之前,您需要显示更多类的代码。

于 2013-01-01T11:01:25.483 回答