如何在sqlite中调用delete函数

时间:2013-08-18 19:56:42

标签: android android-sqlite

我想在我的数据库处理程序文件中使用下面给出的删除功能。当我实现它时,javaNullpointerException即将到来。我肯定错过了一些东西。

删除功能

// Deleting single contact
public void deleteContact(Contact contact) {
    SQLiteDatabase db = this.getWritableDatabase();
    db.delete(TABLE_CONTACTS, KEY_ID + " = ?",new String[] { String.valueOf(contact.getID()) });
    db.close();
}

我想用作:

     DatabaseHandler db = new DatabaseHandler(this);
Contact pm = null;
Intent i;
i = getIntent();
pm._id= i.getExtras().getInt("id");
pm._name = i.getExtras().getString("name");
pm._phone_number = i.getExtras().getString("phone_number");

        // **Some problem is here I am not getting it

                        db.deleteContact(pm);
                        Toast.makeText(getApplicationContext(),"Deleted..",Toast.LENGTH_SHORT).show();

logcat的:

08-19 01:15:00.726: E/AndroidRuntime(12657): FATAL EXCEPTION: main
08-19 01:15:00.726: E/AndroidRuntime(12657): java.lang.NullPointerException
08-19 01:15:00.726: E/AndroidRuntime(12657):    at com.parth.targetthebudget.ViewContact$ListAdapter$2$1.onClick(ViewContact.java:151)
08-19 01:15:00.726: E/AndroidRuntime(12657):    at com.android.internal.app.AlertController$ButtonHandler.handleMessage(AlertController.java:163)
08-19 01:15:00.726: E/AndroidRuntime(12657):    at android.os.Handler.dispatchMessage(Handler.java:99)
08-19 01:15:00.726: E/AndroidRuntime(12657):    at android.os.Looper.loop(Looper.java:130)
08-19 01:15:00.726: E/AndroidRuntime(12657):    at android.app.ActivityThread.main(ActivityThread.java:3687)
08-19 01:15:00.726: E/AndroidRuntime(12657):    at java.lang.reflect.Method.invokeNative(Native Method)
08-19 01:15:00.726: E/AndroidRuntime(12657):    at java.lang.reflect.Method.invoke(Method.java:507)
08-19 01:15:00.726: E/AndroidRuntime(12657):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
08-19 01:15:00.726: E/AndroidRuntime(12657):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
08-19 01:15:00.726: E/AndroidRuntime(12657):    at dalvik.system.NativeStart.main(Native Method)

1 个答案:

答案 0 :(得分:2)

根据我的理解,您正在尝试将数据从1个活动发送到另一个活动,以便您可以删除与数据匹配的记录?

你有联系方式pm = null; 那么你试图在数据库中获取空记录的id。 我确定你的下面这个  http://www.androidhive.info/2011/11/android-sqlite-database-tutorial/ 删除

Contact pm = null;
pm._id= i.getExtras().getInt("id");
pm._name = i.getExtras().getString("name");
pm._phone_number = i.getExtras().getString("phone_number");

添加

Contact pm = db.getContact(i.getExtras().getInt("id"));

将删除与您在意图中发送的内容具有相同ID的记录