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)