将整个手机的联系人列表添加到应用程序数据库中

时间:2015-09-09 04:49:45

标签: android database sqlite contacts android-contacts

我是Android新手并开发了一款应用程序,我需要在启动应用程序时将整个手机的联系人列表存储到我的应用程序数据库中。

当我在网上搜索时,我得到了在应用程序数据库中逐个插入联系人的答案。但我希望将整个联系人列表放入我的数据库,然后处理该联系人数据库。

任何帮助将不胜感激。谢谢:))

我的代码段位于以下答案评论中。

2 个答案:

答案 0 :(得分:1)

似乎没有努力!!无论如何,您可以使用 ContentResolver 类。这提供了设备联系人列表中的联系人列表。这是代码,

ContentResolver cr = getContentResolver();
    Cursor cur = cr.query(ContactsContract.Contacts.CONTENT_URI,
            null, null, null, null);
    if (cur.getCount() > 0) {
        while (cur.moveToNext()) {
              String id = cur.getString(cur.getColumnIndex(ContactsContract.Contacts._ID));
              String name = cur.getString(cur.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
              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()) {
                     String phoneNo = pCur.getString(pCur.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
              Log.e("TAG","Name :: "+Name);
              Log.e("TAG","Phone no :: "+phoneNo);

                 }
                pCur.close();
            }
        }
    }

希望您知道如何在 sqlite 数据库中逐个存储这些联系人。如果有任何疑问,请随时询问

答案 1 :(得分:0)

你需要做两件事:

1。回复所有联系人

检查此Android developer link

此链接包含如何:

  1. 检索联系人列表
  2. 检索联系人的详细信息
  3. 2。将所有数据存储到数据库

    使用'OrmLite'或任何orm将此数据添加到数据库中。 以下是OrmLite的指南。

    希望它会有所帮助。