2014-03-30 49 views
0

如何通过其id/lookupkey检索单个联系人和一些关联数据(例如电子邮件,电话号码,地址等)?如何检索单个联系人

这是我用来添加联系人(实际上它来自互联网,并为我工作)的代码。

// Asking the Contact provider to create a new contact 
    try { 
     result = this.context.getContentResolver().applyBatch(
       ContactsContract.AUTHORITY, ops); 
    } catch (Exception e) { 
     e.printStackTrace(); 
     Toast.makeText(this.context, "Exception: " + e.getMessage(), 
       Toast.LENGTH_SHORT).show(); 
    } 

    Uri myContactUri = result[0].uri; 
    int lastSlash = myContactUri.toString().lastIndexOf("/"); 
    int length = myContactUri.toString().length(); 
    int contactID = Integer.parseInt((String) myContactUri.toString() 
      .subSequence(lastSlash + 1, length)); 

    return contactID; 

现在我想获取这个新的联系人。我该怎么做?所有我想出的是这样的:

ContentResolver content = context.getContentResolver(); 

    String[] projection = { Data.LOOKUP_KEY, Data.MIMETYPE, 
      ContactsContract.Contacts._ID, 
      ContactsContract.Contacts.DISPLAY_NAME, 
      ContactsContract.CommonDataKinds.Phone.NUMBER, 
      ContactsContract.CommonDataKinds.Email.ADDRESS }; 

    // Defines the selection clause 
    String selection = Data.LOOKUP_KEY + " = ?"; 

    // Defines the sort order 
    String sortOrder = Data.LOOKUP_KEY; 

    String[] args = {"2400"}; 

    Cursor cursor = content.query(Data.CONTENT_URI, projection, selection, 
      args, sortOrder); 

当我删除选择我得到所有联系人+他们的所有数据。所以我查了一下我的案例中的关键2400,并希望通过它的lookupkey获取这个联系人。那么,不起作用。 cursor.getCount()返回0.

任何想法?

回答

0

我的解决方案现在是使用以下:

String[] projection = { Data.MIMETYPE, 
      ContactsContract.Contacts._ID, 
      ContactsContract.Contacts.DISPLAY_NAME, 
      ContactsContract.CommonDataKinds.Phone.NUMBER, 
      ContactsContract.CommonDataKinds.Email.ADDRESS }; 

    // Defines the selection clause 
    String selection = ContactsContract.Data.RAW_CONTACT_ID + "=?"; 

    // Defines the sort order 
    String sortOrder = Data.LOOKUP_KEY; 

    String[] args = { id+"" }; 

    Cursor cursor = content.query(Data.CONTENT_URI, projection, selection, 
      args, sortOrder); 

排序顺序并不重要,但我用的是RAW_CONTACT_ID,效果很好!