操作Android 手机通讯录数据库

// 根据ID获得联系人信息实体
 private static EnContactBackUp getEnContactBackUp(String id) {
  ContentResolver resolver = acApplication.getInstance()
    .getContentResolver();
  EnContactBackUp contact = new EnContactBackUp();
  contact.setId(id);
  String value = null;
  // 获得昵称
  Cursor cur = resolver.query(ContactsContract.Data.CONTENT_URI,
    new String[] { Nickname.NAME },
    ContactsContract.Data.CONTACT_ID + "=? and "
      + ContactsContract.Data.MIMETYPE + "=?", new String[] {
      id, Nickname.CONTENT_ITEM_TYPE }, null);
  while (cur.moveToNext()) {
   contact.setNickName(cur.getString(0).replaceAll("#", "#")
     .replaceAll(",", ",").replaceAll(";", ";")
     .replaceAll(":", ":"));
  }
  cur.close();
  // 获得名字序列串
  Cursor nameCur = resolver.query(ContactsContract.Data.CONTENT_URI,
    new String[] { ContactsContract.Data.DATA4,
      ContactsContract.Data.DATA3,
      ContactsContract.Data.DATA2,
      ContactsContract.Data.DATA5,
      ContactsContract.Data.DATA6 },
    ContactsContract.Data.CONTACT_ID + "=? and "
      + ContactsContract.Data.MIMETYPE + "=?", new String[] {
      id, StructuredName.CONTENT_ITEM_TYPE }, null);
  while (nameCur.moveToNext()) {
   value = nameCur.getString(0);
   contact.setPrefix(value != null ? value.replaceAll("#", "#")
     .replaceAll(",", ",").replaceAll(";", ";")
     .replaceAll(":", ":").replace(" ", " ") : value);
   value = nameCur.getString(1);
   contact.setFamilyName(value != null ? value.replaceAll("#", "#")
     .replaceAll(",", ",").replaceAll(";", ";")
     .replaceAll(":", ":").replace(" ", " ") : value);
   value = nameCur.getString(2);
   contact.setGivenName(value != null ? value.replaceAll("#", "#")
     .replaceAll(",", ",").replaceAll(";", ";")
     .replaceAll(":", ":").replace(" ", " ") : value);
   value = nameCur.getString(3);
   contact.setCenterName(value != null ? value.replaceAll("#", "#")
     .replaceAll(",", ",").replaceAll(";", ";")
     .replaceAll(":", ":").replace(" ", " ") : value);
   value = nameCur.getString(4);
   contact.setSuffix(value != null ? value.replaceAll("#", "#")
     .replaceAll(",", ",").replaceAll(";", ";")
     .replaceAll(":", ":").replace(" ", " ") : value);
  }
  nameCur.close();
  // 根据ID查询通讯录号码
  Cursor phoneCursor = resolver.query(
    ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
    new String[] { ContactsContract.CommonDataKinds.Phone.NUMBER,
      ContactsContract.CommonDataKinds.Phone.TYPE },
    ContactsContract.CommonDataKinds.Phone.CONTACT_ID + "=?",
    new String[] { id }, null);
  System.out.println("phone count    " + phoneCursor.getCount());
  while (phoneCursor.moveToNext()) {
   int type = phoneCursor.getInt(1);
   value = phoneCursor.getString(0);
   switch (type) {
   case Phone.TYPE_HOME:
    contact.setHomeTel(value != null ? value.replaceAll("#", "#")
      .replaceAll(",", ",").replaceAll(";", ";")
      .replaceAll(":", ":").replace(" ", " ") : value);
    break;
   case Phone.TYPE_MOBILE:
    contact.setUsePhone(value != null ? value.replaceAll("#", "#")
      .replaceAll(",", ",").replaceAll(";", ";")
      .replaceAll(":", ":").replace(" ", " ") : value);
    break;
   case Phone.TYPE_WORK:
    contact.setOfficeTel(value != null ? value.replaceAll("#", "#")
      .replaceAll(",", ",").replaceAll(";", ";")
      .replaceAll(":", ":").replace(" ", " ") : value);
    break;
   case Phone.TYPE_FAX_HOME:
    contact.setHomeFax(value != null ? value.replaceAll("#", "#")
      .replaceAll(",", ",").replaceAll(";", ";")
      .replaceAll(":", ":").replace(" ", " ") : value);
    break;
   case Phone.TYPE_FAX_WORK:
    contact.setOfficeFax(value != null ? value.replaceAll("#", "#")
      .replaceAll(",", ",").replaceAll(";", ";")
      .replaceAll(":", ":").replace(" ", " ") : value);
    break;
   }
  }
  phoneCursor.close(); // 关闭游标
  // 获得QQ号
  Cursor imCur = resolver.query(ContactsContract.Data.CONTENT_URI,
    new String[] { Im.DATA, Im.PROTOCOL },
    ContactsContract.Data.CONTACT_ID + "=? and "
      + ContactsContract.Data.MIMETYPE + "=?", new String[] {
      id, Im.CONTENT_ITEM_TYPE }, null);
  while (imCur.moveToNext()) {
   int type = imCur.getInt(1);
   value = imCur.getString(0);
   switch (type) {
   case Im.PROTOCOL_QQ: // 匹配为QQ
    contact.setQQNum(value != null ? value.replaceAll("#", "#")
      .replaceAll(",", ",").replaceAll(";", ";")
      .replaceAll(":", ":").replace(" ", " ") : value);
    break;
   }
  }
  imCur.close();
  // 获得职位和公司
  Cursor orgCur = resolver.query(ContactsContract.Data.CONTENT_URI,
    new String[] { Organization.COMPANY, Organization.TITLE,
      Organization.TYPE }, ContactsContract.Data.CONTACT_ID
      + "=? and " + ContactsContract.Data.MIMETYPE + "=?",
    new String[] { id, Organization.CONTENT_ITEM_TYPE }, null);
  while (orgCur.moveToNext()) {
   int type = orgCur.getInt(2);
   switch (type) {
   case Organization.TYPE_WORK:
    value = orgCur.getString(0);
    contact.setCompany(value != null ? value.replaceAll("#", "#")
      .replaceAll(",", ",").replaceAll(";", ";")
      .replaceAll(":", ":").replace(" ", " ") : value);
    value = orgCur.getString(1);
    contact.setPisition(value != null ? value.replaceAll("#", "#")
      .replaceAll(",", ",").replaceAll(";", ";")
      .replaceAll(":", ":").replace(" ", " ") : value);
    break;
   }
  }
  orgCur.close();
  // 获得备注
  Cursor noteCur = resolver.query(ContactsContract.Data.CONTENT_URI,
    new String[] { Note.NOTE }, ContactsContract.Data.CONTACT_ID
      + "=? and " + ContactsContract.Data.MIMETYPE + "=?",
    new String[] { id, Note.CONTENT_ITEM_TYPE }, null);
  while (noteCur.moveToNext()) {
   value = noteCur.getString(0);
   contact.setNote(value != null ? value.replaceAll("#", "#")
     .replaceAll(",", ",").replaceAll(";", ";")
     .replaceAll(":", ":").replace(" ", " ") : value);
  }
  noteCur.close();
  // 获得邮箱信息
  Cursor emailCur = resolver.query(
    ContactsContract.CommonDataKinds.Email.CONTENT_URI,
    new String[] { Email.DATA1, Email.TYPE },
    ContactsContract.CommonDataKinds.Email.CONTACT_ID + "=? and "
      + ContactsContract.CommonDataKinds.Email.MIMETYPE
      + "=?", new String[] { id, Email.CONTENT_ITEM_TYPE },
    null);
  while (emailCur.moveToNext()) {
   int type = emailCur.getInt(1);
   value = emailCur.getString(0);
   switch (type) {
   case Email.TYPE_HOME:
    contact.setHomeMailBox(value != null ? value
      .replaceAll("#", "#").replaceAll(",", ",")
      .replaceAll(";", ";").replaceAll(":", ":")
      .replace(" ", " ") : value);
    break;
   case Email.TYPE_WORK:
    contact.setOfficeMailBox(value != null ? value
      .replaceAll("#", "#").replaceAll(",", ",")
      .replaceAll(";", ";").replaceAll(":", ":")
      .replace(" ", " ") : value);
    break;
   case Email.TYPE_OTHER:
    contact.setElecMailBox(value != null ? value
      .replaceAll("#", "#").replaceAll(",", ",")
      .replaceAll(";", ";").replaceAll(":", ":")
      .replace(" ", " ") : value);
    break;
   }
  }
  emailCur.close();
  // 获得网址
  Cursor webCur = resolver.query(ContactsContract.Data.CONTENT_URI,
    new String[] { Website.URL, Website.TYPE },
    ContactsContract.CommonDataKinds.Website.CONTACT_ID + "=? and "
      + ContactsContract.CommonDataKinds.Website.MIMETYPE
      + "=?", new String[] { id, Website.CONTENT_ITEM_TYPE },
    null);
  while (webCur.moveToNext()) {
   int type = webCur.getInt(1);
   switch (type) {
   case Website.TYPE_OTHER:
    value = webCur.getString(0);
    contact.setPersonWeb(value != null ? value.replaceAll("#", "#")
      .replaceAll(",", ",").replaceAll(";", ";")
      .replaceAll(":", ":").replace(" ", " ") : value);
    break;
   }
  }
  webCur.close();
  return contact;
 }

 

 

 

// 通讯录还原 添加联系人
 public static long updateContact(EnContactBackUp contact) {
  // 获得查询分析器
  ContentValues values = new ContentValues();
  ContentResolver res = acApplication.getInstance().getContentResolver();
  String value = null;
  // 插入通讯录
  Uri rawContactUri = res.insert(
    ContactsContract.RawContacts.CONTENT_URI, values);
  long rawContactId = ContentUris.parseId(rawContactUri);
  values.clear();
  value = contact.getNickName();
  if (value != null && !value.equals("") && !value.equals(" ")) {
   // 设置昵称
   values.put(ContactsContract.Data.RAW_CONTACT_ID, rawContactId);
   values.put(Nickname.NAME, value);
   values.put(Data.MIMETYPE, Nickname.CONTENT_ITEM_TYPE);
   res.insert(ContactsContract.Data.CONTENT_URI, values);
   values.clear();
  }

  // 设置名字信息
  values.put(ContactsContract.Data.RAW_CONTACT_ID, rawContactId);
  values.put(Data.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE);
  value = contact.getPrefix();
  if (value != null && !value.equals("") && !value.equals(" ")) {
   values.put(StructuredName.PREFIX, value);
  }
  value = contact.getFamilyName();
  if (value != null && !value.equals("") && !value.equals(" ")) {
   values.put(StructuredName.FAMILY_NAME, value);
  }
  value = contact.getGivenName();
  if (value != null && !value.equals("") && !value.equals(" ")) {
   values.put(StructuredName.GIVEN_NAME, value);
  }
  value = contact.getCenterName();
  if (value != null && !value.equals("") && !value.equals(" ")) {
   values.put(StructuredName.MIDDLE_NAME, value);
  }
  value = contact.getSuffix();
  if (value != null && !value.equals("") && !value.equals(" ")) {
   values.put(StructuredName.SUFFIX, value);
  }
  res.insert(ContactsContract.Data.CONTENT_URI, values);
  values.clear();

  // 添加手机号码
  value = contact.getUsePhone();
  if (value != null && !value.equals("")) {
   values.put(ContactsContract.Data.RAW_CONTACT_ID, rawContactId);
   values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);
   values.put(ContactsContract.CommonDataKinds.Phone.NUMBER, value);
   values.put(ContactsContract.CommonDataKinds.Phone.TYPE,
     Phone.TYPE_MOBILE);
   res.insert(ContactsContract.Data.CONTENT_URI, values);
   values.clear();
  }

  // 添加家庭号码
  value = contact.getHomeTel();
  if (value != null && !value.equals("")) {
   values.put(ContactsContract.Data.RAW_CONTACT_ID, rawContactId);
   values.put(ContactsContract.CommonDataKinds.Phone.NUMBER, value);
   values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);
   values.put(ContactsContract.CommonDataKinds.Phone.TYPE,
     Phone.TYPE_HOME);
   res.insert(ContactsContract.Data.CONTENT_URI, values);
   values.clear();
  }
  // 添加单位号码
  value = contact.getOfficeTel();
  if (value != null && !value.equals("")) {
   values.put(ContactsContract.Data.RAW_CONTACT_ID, rawContactId);
   values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);
   values.put(ContactsContract.CommonDataKinds.Phone.NUMBER, value);
   values.put(ContactsContract.CommonDataKinds.Phone.TYPE,
     Phone.TYPE_WORK);
   res.insert(ContactsContract.Data.CONTENT_URI, values);
   values.clear();
  }
  // 添加家庭传真
  value = contact.getHomeFax();
  if (value != null && !value.equals("")) {
   values.put(ContactsContract.Data.RAW_CONTACT_ID, rawContactId);
   values.put(ContactsContract.CommonDataKinds.Phone.NUMBER, value);
   values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);
   values.put(ContactsContract.CommonDataKinds.Phone.TYPE,
     Phone.TYPE_FAX_HOME);
   res.insert(ContactsContract.Data.CONTENT_URI, values);
   values.clear();
  }
  // 添加办公传真
  value = contact.getOfficeFax();
  if (value != null && !value.equals("")) {
   values.put(ContactsContract.Data.RAW_CONTACT_ID, rawContactId);
   values.put(ContactsContract.CommonDataKinds.Phone.NUMBER, value);
   values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);
   values.put(ContactsContract.CommonDataKinds.Phone.TYPE,
     Phone.TYPE_FAX_WORK);
   res.insert(ContactsContract.Data.CONTENT_URI, values);
   values.clear();
  }

  // 添加QQ号码
  value = contact.getQQNum();
  if (value != null && !value.equals("")) {
   values.put(ContactsContract.Data.RAW_CONTACT_ID, rawContactId);
   values.put(ContactsContract.Data.MIMETYPE, Im.CONTENT_ITEM_TYPE);
   values.put(Im.DATA, value);
   values.put(Im.PROTOCOL, Im.PROTOCOL_QQ);
   res.insert(ContactsContract.Data.CONTENT_URI, values);
   values.clear();
  }
  // 添加公司和职位
  if ((contact.getCompany() != null && !contact.getCompany().equals(""))
    || (contact.getPisition() != null && !contact.getPisition()
      .equals(""))) {
   values.put(ContactsContract.Data.RAW_CONTACT_ID, rawContactId);
   values.put(ContactsContract.Data.MIMETYPE,
     Organization.CONTENT_ITEM_TYPE);
   if (contact.getCompany() != null
     && !contact.getCompany().equals("")) {
    values.put(Organization.COMPANY, contact.getCompany());
   }
   if (contact.getPisition() != null
     || !contact.getPisition().equals("")) {
    values.put(Organization.TITLE, contact.getPisition());
   }
   values.put(Organization.TYPE, Organization.TYPE_WORK);
   res.insert(ContactsContract.Data.CONTENT_URI, values);
   values.clear();
  }
  // 添加备注
  value = contact.getNote();
  if (value != null && !value.equals("")) {
   values.put(ContactsContract.Data.RAW_CONTACT_ID, rawContactId);
   values.put(ContactsContract.Data.MIMETYPE, Note.CONTENT_ITEM_TYPE);
   values.put(Note.NOTE, value);
   res.insert(ContactsContract.Data.CONTENT_URI, values);
   values.clear();
  }
  // 添加电子邮箱
  value = contact.getElecMailBox();
  if (value != null && !value.equals("")) {
   values.put(ContactsContract.CommonDataKinds.Email.RAW_CONTACT_ID,
     rawContactId);
   values.put(ContactsContract.Data.MIMETYPE, Email.CONTENT_ITEM_TYPE);
   values.put(Email.DATA1, value);
   values.put(Email.TYPE, Email.TYPE_OTHER);
   res.insert(ContactsContract.Data.CONTENT_URI, values);
   values.clear();
  }
  // 添加家庭邮箱
  value = contact.getHomeMailBox();
  if (value != null && !value.equals("")) {
   values.put(ContactsContract.CommonDataKinds.Email.RAW_CONTACT_ID,
     rawContactId);
   values.put(ContactsContract.Data.MIMETYPE, Email.CONTENT_ITEM_TYPE);
   values.put(Email.DATA1, value);
   values.put(Email.TYPE, Email.TYPE_HOME);
   res.insert(ContactsContract.Data.CONTENT_URI, values);
   values.clear();
  }
  // 添加单位邮箱
  value = contact.getOfficeMailBox();
  if (value != null && !value.equals("")) {
   values.put(ContactsContract.CommonDataKinds.Email.RAW_CONTACT_ID,
     rawContactId);
   values.put(ContactsContract.Data.MIMETYPE, Email.CONTENT_ITEM_TYPE);
   values.put(Email.DATA1, value);
   values.put(Email.TYPE, Email.TYPE_WORK);
   res.insert(ContactsContract.Data.CONTENT_URI, values);
   values.clear();
  }
  // 添加网站
  value = contact.getPersonWeb();
  if (value != null && !value.equals("")) {
   values.put(ContactsContract.CommonDataKinds.Website.RAW_CONTACT_ID,
     rawContactId);
   values.put(ContactsContract.Data.MIMETYPE,
     Website.CONTENT_ITEM_TYPE);
   values.put(Website.URL, value);
   values.put(Website.TYPE, Website.TYPE_OTHER);
   res.insert(ContactsContract.Data.CONTENT_URI, values);
   values.clear();
  }
  return rawContactId;
 }

你可能感兴趣的:(操作Android 手机通讯录数据库)