1

我的数据库中有一个表,其中包含以下字段:id、group_id、uri_id、name、phone。在我的数据库管理器文件中,我有一个函数来检查组中是否存在 uri_id。这是功能:

public boolean is_contact_in_group(String uri_id, int group_id)
{
    SQLiteDatabase db = db_helper.getReadableDatabase();

    Cursor mContactsCursor = db.query(Constants.TABLE_NAME_GROUP_CONTACTS, null, 
            "group_id="+group_id+"&contact_uri_id="+uri_id, null, null, null, null);


    if(mContactsCursor.moveToFirst())
    {
        mContactsCursor.close();
        db.close();
        return true;
    } else {
        mContactsCursor.close();
        db.close();
        return false;
    }

}

现在在我的活动中,我只想记录输出:

private void add_new_contact(String uri_id, String name, String number)
{
    int group_id = curr_group_id;
    String contact_uri_id = uri_id;
    String contact_name = name;
    String contact_phone = number;
    Log.i(DEBUG_TAG, "Is contact exist: "+manager.is_contact_in_group(contact_uri_id, group_id));

}

但是每次我得到false,即使有一个具有特定 group_id 和 uri_id 的记录。

为什么会发生以及如何解决?

4

2 回答 2

2

我想这是因为你的WHERE条款是错误的。

改变

"group_id="+group_id+"&contact_uri_id="+uri_id

"group_id="+group_id+" AND contact_uri_id="+uri_id
于 2013-09-26T19:55:13.350 回答
0

试试这个。

光标 mContactsCursor = db.query(Constants.TABLE_NAME_GROUP_CONTACTS, null, "group_id = " + group_id + " & contact_uri_id = " + uri_id, null, null, null, null);

您的查询在句子之间没有空格。

于 2013-09-26T19:55:34.680 回答