电话号码

电话号码存储在自己的表中,需要单独查询。要查询电话号码表,请使用存储在SDK变量ContactsContract.CommonDataKinds.Phone.CONTENT_URI中的URI。使用WHERE条件获取指定联系人的电话号码。

if (Integer.parseInt(cur.getString(

cur.getColumnIndex(ContactsContract.Contacts.HAS_PHONE_NUMBER))) > 0) {

Cursor pCur = cr.query(

ContactsContract.CommonDataKinds.Phone.CONTENT_URI,

null,

ContactsContract.CommonDataKinds.Phone.CONTACT_ID +" = ?",

new String[]{id}, null);

while (pCur.moveToNext()) {

// Do something with phones

}

pCur.close();

}

针对Android联系人SQLite数据库执行第二个查询。将根据存储在ContactsContract.CommonDataKinds.Phone.CONTENT_URI中的URI查询电话号码。联系人ID作为ContactsContract.CommonDataKinds.Phone.CONTACT_ID存储在电话表中,WHERE子句用于限制返回的数据。

电子邮件地址

查询电子邮件地址与电话号码类似。必须执行查询才能从数据库获取电子邮件地址。查询存储在ContactsContract.CommonDataKinds.Email.CONTENT_URI中的URI以查询电子邮件地址表。

Cursor emailCur = cr.query(

ContactsContract.CommonDataKinds.Email.CONTENT_URI,

null,

ContactsContract.CommonDataKinds.Email.CONTACT_ID + " = ?",

new String[]{id}, null);

while (emailCur.moveToNext()) {

// This would allow you get several email addresses

// if the email addresses were stored in an array

String email = emailCur.getString(

emailCur.getColumnIndex(ContactsContract.CommonDataKinds.Email.DATA));

String emailType = emailCur.getString(

emailCur.getColumnIndex(ContactsContract.CommonDataKinds.Email.TYPE));

}

emailCur.close();

与电话查询一样,电子邮件表的字段名称也存储在ContactsContract.CommonDataKinds下。电子邮件查询在ContactsContract.CommonDataKinds.Email.CONTENT_URI中的URI上执行,WHERE子句必须与ContactsContract.CommonDataKinds.Email.CONTACT_ID字段匹配。由于多个电子邮件地址可以存储循环通过在游标中返回的记录。

更多教程here

此方法需要Android API版本5或更高版本。

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐