我正在使用 Android 联系人并尝试获取特定的数据。我已经可以获得电子邮件、电话号码、他们的姓名等。但是我很难获得关系字段。
所以我的目标是:给定一个特定的用户 ID(来自 Android 上的联系人数据库),找出他们的关系字段。
我正在使用 Android 联系人并尝试获取特定的数据。我已经可以获得电子邮件、电话号码、他们的姓名等。但是我很难获得关系字段。
所以我的目标是:给定一个特定的用户 ID(来自 Android 上的联系人数据库),找出他们的关系字段。
这应该有效。这个想法是连接数据表中的搜索,但使用来自 CommonDataKinds 的东西。这是在 where 子句 ... 中完成的Data.MIMETYPE == CommonDataKinds.Relation.CONTENT_ITEM_TYPE
。这将使您获得所有关系内容的行。
import android.database.Cursor;
import android.net.Uri;
import android.provider.ContactsContract.CommonDataKinds.Relation;
import android.provider.ContactsContract.Data;
import android.util.Log;
...
public void logCatTheRelation(long contactId){
Uri uri = Data.CONTENT_URI;
String where = String.format(
"%s = ? AND %s = ?",
Data.MIMETYPE,
Relation.CONTACT_ID);
String[] whereParams = new String[] {
Relation.CONTENT_ITEM_TYPE,
Long.toString(contactId),
};
String[] selectColumns = new String[]{
Relation.NAME,
// add additional columns here
};
Cursor relationCursor = this.getContentResolver().query(
uri,
selectColumns,
where,
whereParams,
null);
try{
if (relationCursor.moveToFirst()) {
Log.d("gizm0", relationCursor.getString(
relationCursor.getColumnIndex(Relation.NAME)));
}
Log.d("gizm0", "sadly no relation ... ");
}finally{
relationCursor.close();
}
}