`
407827531
  • 浏览: 1073979 次
  • 性别: Icon_minigender_1
  • 来自: 厦门
社区版块
存档分类
最新评论

2.0联系人增、删、改、查

 
阅读更多

推荐安卓开发神器(里面有各种UI特效和android代码库实例)

本章和大家分享的是手机通讯录方面的经验,需求背景:对手机通讯录进行增、删、改、查,或者有时候App需要与手机 contacts进行交互或共享contacts。

我们都知道android系统没有完全将contacts向developer开放,开发人员只能通过android提供的有限的Api对contacts进行操作,我们只能通过ContentProvider对contacts的数据进行增、删、改、查等操作,并不能改变到其表结构。

首先,我们来看下如何通过ContentProvider查找contacts,以下我以查找其姓、名、公司、家庭电话、工作电话、移动电话、传真、邮箱、城市、省份、国家、出生年月为例:

 

 

	/**
	 * 取得family_name和given_name
	 */
	Cursor nameCur=cr.query(ContactsContract.Data.CONTENT_URI,
			new String[] {Data.CONTACT_ID, StructuredName.DISPLAY_NAME, StructuredName.FAMILY_NAME, StructuredName.GIVEN_NAME, StructuredName.MIDDLE_NAME},
			 ContactsContract.Data.CONTACT_ID + "=?" + " AND "
          + ContactsContract.Data.MIMETYPE + "='" +  ContactsContract.CommonDataKinds.StructuredName.CONTENT_ITEM_TYPE + "'",
			new String[]{android_id}, null);
	if(nameCur.moveToFirst()){
		firstName=nameCur.getString(nameCur.getColumnIndex(ContactsContract.CommonDataKinds.StructuredName.FAMILY_NAME));
		lastName=nameCur.getString(nameCur.getColumnIndex(ContactsContract.CommonDataKinds.StructuredName.GIVEN_NAME));
	}
	nameCur.close();
 
	Cursor companyCur=cr.query(ContactsContract.Data.CONTENT_URI,
			new String[] {CommonDataKinds.Organization.COMPANY},
			 ContactsContract.Data.CONTACT_ID + "=?" + " AND "
          + ContactsContract.Data.MIMETYPE + "='" +  ContactsContract.CommonDataKinds.Organization.CONTENT_ITEM_TYPE + "'",
			new String[]{android_id}, null);
 
	if(companyCur.moveToFirst()){
			company=companyCur.getString(companyCur.getColumnIndex(CommonDataKinds.Organization.COMPANY));
		}
	companyCur.close();
 
	// 根据contact_ID取得HomePhone号码
	Cursor homePhoneCur = cr.query(ContactsContract.Data.CONTENT_URI,
			new String[] {ContactsContract.CommonDataKinds.Phone.NUMBER},
        ContactsContract.Data.CONTACT_ID + "=?" + " AND "
          + ContactsContract.Data.MIMETYPE + "=? "+" AND "
          +ContactsContract.CommonDataKinds.Phone.TYPE + "=?",
        new String[]{android_id,ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.Phone.TYPE_HOME)}, null);
	if(homePhoneCur.moveToFirst()){
		homePhone=homePhoneCur.getString(homePhoneCur.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
	}
	homePhoneCur.close();
 
	// 根据contact_ID取得WorkPhone号码
	Cursor workPhoneCur = cr.query(ContactsContract.Data.CONTENT_URI,
			new String[] {ContactsContract.CommonDataKinds.Phone.NUMBER},
        ContactsContract.Data.CONTACT_ID + "=?" + " AND "
          + ContactsContract.Data.MIMETYPE + "=? "+" AND "
          +ContactsContract.CommonDataKinds.Phone.TYPE + "=?",
        new String[]{android_id,ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.Phone.TYPE_WORK)}, null);
	if(workPhoneCur.moveToFirst()){
		workPhone=workPhoneCur.getString(workPhoneCur.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
	}
	workPhoneCur.close();
 
	// 根据contact_ID取得MobilePhone号码
	Cursor mobilePhoneCur = cr.query(ContactsContract.Data.CONTENT_URI,
			new String[] {ContactsContract.CommonDataKinds.Phone.NUMBER},
        ContactsContract.Data.CONTACT_ID + "=?" + " AND "
          + ContactsContract.Data.MIMETYPE + "=? "+" AND "
          +ContactsContract.CommonDataKinds.Phone.TYPE + "=?",
        new String[]{android_id,ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.Phone.TYPE_MOBILE)}, null);
	if(mobilePhoneCur.moveToFirst()){
		mobilePhone=mobilePhoneCur.getString(mobilePhoneCur.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
	}
	mobilePhoneCur.close();
 
	// 根据contact_ID取得MobilePhone号码
	Cursor faxPhoneCur = cr.query(ContactsContract.Data.CONTENT_URI,
			new String[] {ContactsContract.CommonDataKinds.Phone.NUMBER},
        ContactsContract.Data.CONTACT_ID + "=?" + " AND "
          + ContactsContract.Data.MIMETYPE + "=? "+" AND "
          +ContactsContract.CommonDataKinds.Phone.TYPE + "=?",
        new String[]{android_id,ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.Phone.TYPE_FAX_HOME)}, null);
	if(faxPhoneCur.moveToFirst()){
		faxPhone=faxPhoneCur.getString(faxPhoneCur.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
	}
	faxPhoneCur.close();
 
	// 根据contact_ID取得MobilePhone号码
	Cursor emailCur = cr.query(ContactsContract.Data.CONTENT_URI,
			new String[] {ContactsContract.CommonDataKinds.Email.DATA},
        ContactsContract.Data.CONTACT_ID + "=?" + " AND "
          + ContactsContract.Data.MIMETYPE + "=? "+" AND "
          +ContactsContract.CommonDataKinds.Phone.TYPE + "=?",
        new String[]{android_id,ContactsContract.CommonDataKinds.Email.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.Email.TYPE_WORK)}, null);
	if(emailCur.moveToFirst()){
		email=emailCur.getString(emailCur.getColumnIndex(ContactsContract.CommonDataKinds.Email.DATA));
	}
	emailCur.close();
 
	// 根据contact_ID取得MobilePhone号码
	Cursor addressCur = cr.query(ContactsContract.Data.CONTENT_URI,
			new String[] {ContactsContract.CommonDataKinds.StructuredPostal.CITY,ContactsContract.CommonDataKinds.StructuredPostal.REGION,
			ContactsContract.CommonDataKinds.StructuredPostal.COUNTRY},
        ContactsContract.Data.CONTACT_ID + "=?" + " AND "
        + ContactsContract.Data.MIMETYPE + "=? ",
        new String[]{android_id,ContactsContract.CommonDataKinds.StructuredPostal.CONTENT_ITEM_TYPE}, null);
	if(addressCur.moveToFirst()){
		city=addressCur.getString(addressCur.getColumnIndex(ContactsContract.CommonDataKinds.StructuredPostal.CITY));
		state=addressCur.getString(addressCur.getColumnIndex(ContactsContract.CommonDataKinds.StructuredPostal.REGION));
		country=addressCur.getString(addressCur.getColumnIndex(ContactsContract.CommonDataKinds.StructuredPostal.COUNTRY));
	}
	addressCur.close();
 
	// 根据contact_ID取得MobilePhone号码
	Cursor birthdayCur = cr.query(ContactsContract.Data.CONTENT_URI,
			new String[] {ContactsContract.CommonDataKinds.Event.DATA},
        ContactsContract.Data.CONTACT_ID + "=?" + " AND "
          + ContactsContract.Data.MIMETYPE + "=? "+" AND "
          + ContactsContract.CommonDataKinds.Event.TYPE + "=? ",
        new String[]{android_id,ContactsContract.CommonDataKinds.Event.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.Event.TYPE_BIRTHDAY)}, null);
	if(birthdayCur.moveToFirst()){
		birthday=birthdayCur.getString(birthdayCur.getColumnIndex(ContactsContract.CommonDataKinds.Event.DATA));
	}
	birthdayCur.close();

以上只是查找了contacts的部分字段,同鞋们可以自行拓展,比如说查找其IM,Organization,Nickname,WebSite等等.

得到contacts联系人之后,我们可以对其做相应的修改,修改完成后,我们要将数据更新到android contacts数据库中,以下就是更新的范例:

 

 

 

  	ArrayList ops =
	          new ArrayList();
		// 更新family_name和given_name
	 ops.add(ContentProviderOperation.newUpdate(ContactsContract.Data.CONTENT_URI)
	          .withSelection(ContactsContract.Data.CONTACT_ID + "=?" + " AND "
	        		  + ContactsContract.Data.MIMETYPE + "=?",
	        		  new String[]{android_id,ContactsContract.CommonDataKinds.StructuredName.CONTENT_ITEM_TYPE})
                        .withValue(ContactsContract.CommonDataKinds.StructuredName.FAMILY_NAME, firstN)
                        .withValue(ContactsContract.CommonDataKinds.StructuredName.GIVEN_NAME, lastN)
                        .build());
	 // 更新comany
	 ops.add(ContentProviderOperation.newUpdate(ContactsContract.Data.CONTENT_URI)
	          .withSelection(ContactsContract.Data.CONTACT_ID + "=?" + " AND "
	        		  + ContactsContract.Data.MIMETYPE + "=?"+ " AND "
	        		  + ContactsContract.CommonDataKinds.Organization.TYPE + "=?",
	        		  new String[]{android_id,ContactsContract.CommonDataKinds.Organization.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.Organization.TYPE_WORK)})
                       .withValue(ContactsContract.CommonDataKinds.Organization.COMPANY, com)
                       .build());
	 // 更新homePhone
	 ops.add(ContentProviderOperation.newUpdate(ContactsContract.Data.CONTENT_URI)
	          .withSelection(ContactsContract.Data.CONTACT_ID + "=?" + " AND "
	        		  + ContactsContract.Data.MIMETYPE + "=?"+ " AND "
	        		  + ContactsContract.CommonDataKinds.Organization.TYPE + "=?",
	        		  new String[]{android_id,ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.Phone.TYPE_HOME)})
                      .withValue(ContactsContract.CommonDataKinds.Phone.NUMBER, hp)
                      .build());
	 // 更新workPhone
	 ops.add(ContentProviderOperation.newUpdate(ContactsContract.Data.CONTENT_URI)
	          .withSelection(ContactsContract.Data.CONTACT_ID + "=?" + " AND "
	        		  + ContactsContract.Data.MIMETYPE + "=?"+ " AND "
	        		  + ContactsContract.CommonDataKinds.Organization.TYPE + "=?",
	        		  new String[]{android_id,ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.Phone.TYPE_WORK)})
                     .withValue(ContactsContract.CommonDataKinds.Phone.NUMBER,wp)
                     .build());
	// 更新mobilePhone
	 ops.add(ContentProviderOperation.newUpdate(ContactsContract.Data.CONTENT_URI)
	          .withSelection(ContactsContract.Data.CONTACT_ID + "=?" + " AND "
	        		  + ContactsContract.Data.MIMETYPE + "=?"+ " AND "
	        		  + ContactsContract.CommonDataKinds.Organization.TYPE + "=?",
	        		  new String[]{android_id,ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.Phone.TYPE_MOBILE)})
                    .withValue(ContactsContract.CommonDataKinds.Phone.NUMBER,mp)
                    .build());
	// 更新faxPhone
	 ops.add(ContentProviderOperation.newUpdate(ContactsContract.Data.CONTENT_URI)
	          .withSelection(ContactsContract.Data.CONTACT_ID + "=?" + " AND "
	        		  + ContactsContract.Data.MIMETYPE + "=?"+ " AND "
	        		  + ContactsContract.CommonDataKinds.Organization.TYPE + "=?",
	        		  new String[]{android_id,ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.Phone.TYPE_FAX_HOME)})
                    .withValue(ContactsContract.CommonDataKinds.Phone.NUMBER,fp)
                    .build());
	// 更新email
	 ops.add(ContentProviderOperation.newUpdate(ContactsContract.Data.CONTENT_URI)
	          .withSelection(ContactsContract.Data.CONTACT_ID + "=?" + " AND "
	        		  + ContactsContract.Data.MIMETYPE + "=?"+ " AND "
	        		  + ContactsContract.CommonDataKinds.Email.TYPE + "=?",
	        		  new String[]{android_id,ContactsContract.CommonDataKinds.Email.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.Email.TYPE_WORK)})
                   .withValue(ContactsContract.CommonDataKinds.Email.DATA,em)
                   .build());
	// 更新city,state,country
	 ops.add(ContentProviderOperation.newUpdate(ContactsContract.Data.CONTENT_URI)
	          .withSelection(ContactsContract.Data.CONTACT_ID + "=?" + " AND "
	        		  + ContactsContract.Data.MIMETYPE + "=?"+ " AND "
	        		  + ContactsContract.CommonDataKinds.StructuredPostal.TYPE + "=?",
	        		  new String[]{android_id,ContactsContract.CommonDataKinds.StructuredPostal.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.StructuredPostal.TYPE_HOME)})
                  .withValue(ContactsContract.CommonDataKinds.StructuredPostal.CITY, city)
                  .withValue(ContactsContract.CommonDataKinds.StructuredPostal.REGION, state)
                  .withValue(ContactsContract.CommonDataKinds.StructuredPostal.COUNTRY,cou)
                  .build());
	// 更新birthday
	 ops.add(ContentProviderOperation.newUpdate(ContactsContract.Data.CONTENT_URI)
	          .withSelection(ContactsContract.Data.CONTACT_ID + "=?" + " AND "
	        		  + ContactsContract.Data.MIMETYPE + "=?"+ " AND "
	        		  + ContactsContract.CommonDataKinds.Event.TYPE + "=?",
	        		  new String[]{android_id,ContactsContract.CommonDataKinds.Event.CONTENT_ITEM_TYPE,String.valueOf(ContactsContract.CommonDataKinds.Event.TYPE_BIRTHDAY)})
                 .withValue(ContactsContract.CommonDataKinds.Event.DATA, bir)
                 .build());
	 try
     {
         ContentProviderResult[] res = context.getContentResolver().applyBatch(ContactsContract.AUTHORITY, ops);
	//  Log.i("contact", "android_id="+android_id+",firstName="+firstName+",lastName="+lastName);
	//  appState.db.insertContactToTag(tagId,String.valueOf(contactId));
     }
     catch (RemoteException e)
     {
         // error
     }catch (OperationApplicationException e)
     {
         // error
     }

同样以上更新也仅是对contact的部分字段进行了更新,我相信聪明的你,仔细阅读,细细推敲一番,定能找到其中的规律,从而对犹如IM,Nickname,Event,Organization等字段进行更新。

以上只是对已经存在的contacts进行操作,那么我们一开始该如何向里面插入一条数据呢,以下代码是实现向数据库中插入一条数据的操作。

 

 

 

	ArrayList ops = new ArrayList();
		int rawContactInsertIndex = ops.size();
 
        ops.add(ContentProviderOperation.newInsert(ContactsContract.RawContacts.CONTENT_URI)
                .withValue(ContactsContract.RawContacts.ACCOUNT_TYPE, null)
                .withValue(ContactsContract.RawContacts.ACCOUNT_NAME, null)
                .build());
 
      //------------------------------------------------------ Names
        if(firstN != null && lastN!=null )
        {
            ops.add(ContentProviderOperation.newInsert(ContactsContract.Data.CONTENT_URI)
                    .withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, rawContactInsertIndex)
                    .withValue(ContactsContract.Data.MIMETYPE,
                            ContactsContract.CommonDataKinds.StructuredName.CONTENT_ITEM_TYPE)
                    .withValue(ContactsContract.CommonDataKinds.StructuredName.DISPLAY_NAME, firstN+lastN)
                    .withValue(ContactsContract.CommonDataKinds.StructuredName.FAMILY_NAME, firstN)
                    .withValue(ContactsContract.CommonDataKinds.StructuredName.GIVEN_NAME, lastN)
                    .build());
        }  
 
      //------------------------------------------------------ Organization
        if(com!=null)
        {
            ops.add(ContentProviderOperation.newInsert(ContactsContract.Data.CONTENT_URI)
                    .withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, rawContactInsertIndex)
                    .withValue(ContactsContract.Data.MIMETYPE,
                            ContactsContract.CommonDataKinds.Organization.CONTENT_ITEM_TYPE)
                    .withValue(ContactsContract.CommonDataKinds.Organization.COMPANY, com)
                    .withValue(ContactsContract.CommonDataKinds.Organization.TYPE, ContactsContract.CommonDataKinds.Organization.TYPE_WORK)
                    .build());
        }
 
      //------------------------------------------------------ Home Numbers
        if(hp!= null)
        {
            ops.add(ContentProviderOperation.newInsert(ContactsContract.Data.CONTENT_URI)
                    .withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, rawContactInsertIndex)
                    .withValue(ContactsContract.Data.MIMETYPE,
                            ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE)
                    .withValue(ContactsContract.CommonDataKinds.Phone.NUMBER, hp)
                    .withValue(ContactsContract.CommonDataKinds.Phone.TYPE,
                            ContactsContract.CommonDataKinds.Phone.TYPE_HOME)
                    .build());
        }
      //------------------------------------------------------ Work Numbers
        if(wp != null)
        {
            ops.add(ContentProviderOperation.newInsert(ContactsContract.Data.CONTENT_URI)
                    .withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, rawContactInsertIndex)
                    .withValue(ContactsContract.Data.MIMETYPE,
                            ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE)
                    .withValue(ContactsContract.CommonDataKinds.Phone.NUMBER, wp)
                    .withValue(ContactsContract.CommonDataKinds.Phone.TYPE,
                            ContactsContract.CommonDataKinds.Phone.TYPE_WORK)
                    .build());
        }
      //------------------------------------------------------ Mobile Number
        if(mp != null)
        {
            ops.add(ContentProviderOperation.newInsert(ContactsContract.Data.CONTENT_URI)
                    .withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, rawContactInsertIndex)
                    .withValue(ContactsContract.Data.MIMETYPE,
                            ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE)
                    .withValue(ContactsContract.CommonDataKinds.Phone.NUMBER, mp)
                    .withValue(ContactsContract.CommonDataKinds.Phone.TYPE,
                            ContactsContract.CommonDataKinds.Phone.TYPE_MOBILE)
                    .build());
        }
      //------------------------------------------------------ Fax Number
        if(fp != null)
        {
            ops.add(ContentProviderOperation.newInsert(ContactsContract.Data.CONTENT_URI)
                    .withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, rawContactInsertIndex)
                    .withValue(ContactsContract.Data.MIMETYPE,
                            ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE)
                    .withValue(ContactsContract.CommonDataKinds.Phone.NUMBER, fp)
                    .withValue(ContactsContract.CommonDataKinds.Phone.TYPE,
                            ContactsContract.CommonDataKinds.Phone.TYPE_FAX_HOME)
                    .build());
        }
 
      //------------------------------------------------------ Email
        if(em != null)
        {
             ops.add(ContentProviderOperation.newInsert(ContactsContract.Data.CONTENT_URI)
                        .withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, rawContactInsertIndex)
                        .withValue(ContactsContract.Data.MIMETYPE,
                                ContactsContract.CommonDataKinds.Email.CONTENT_ITEM_TYPE)
                        .withValue(ContactsContract.CommonDataKinds.Email.DATA, em)
                        .withValue(ContactsContract.CommonDataKinds.Email.TYPE, ContactsContract.CommonDataKinds.Email.TYPE_WORK)
                        .build());
        }
      //------------------------------------------------------ City,state,country
        if(city != null)
        {
             ops.add(ContentProviderOperation.newInsert(ContactsContract.Data.CONTENT_URI)
                        .withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, rawContactInsertIndex)
                        .withValue(ContactsContract.Data.MIMETYPE,
                                ContactsContract.CommonDataKinds.StructuredPostal.CONTENT_ITEM_TYPE)
                        .withValue(ContactsContract.CommonDataKinds.StructuredPostal.CITY, city)
                        .withValue(ContactsContract.CommonDataKinds.StructuredPostal.REGION, state)
                        .withValue(ContactsContract.CommonDataKinds.StructuredPostal.COUNTRY,cou)
                        .withValue(ContactsContract.CommonDataKinds.StructuredPostal.TYPE,
                        		ContactsContract.CommonDataKinds.StructuredPostal.TYPE_HOME)
                        .build());
        }
 
      //------------------------------------------------------ Birthday
        if(bir != null)
        {
             ops.add(ContentProviderOperation.newInsert(ContactsContract.Data.CONTENT_URI)
                        .withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, rawContactInsertIndex)
                        .withValue(ContactsContract.Data.MIMETYPE,
                                ContactsContract.CommonDataKinds.Event.CONTENT_ITEM_TYPE)
                        .withValue(ContactsContract.CommonDataKinds.Event.DATA, bir)
                        .withValue(ContactsContract.CommonDataKinds.Event.TYPE,
                        		ContactsContract.CommonDataKinds.Event.TYPE_BIRTHDAY)
                        .build());
        }
        try
        {
            ContentProviderResult[] res = context.getContentResolver().applyBatch(ContactsContract.AUTHORITY, ops);
 
            return res;
        }
        catch (RemoteException e)
        {
            // error
        }catch (OperationApplicationException e)
        {
            // error
        }

实现以上代码便可将一条数据插入到contacts数据库中,同样,你也可以插入其他的字段,而且你也可以细细研究下ContentProviderResult[],看看进行这些操作后,其返回的结果都是什么。

以上实现了对android contacts 增、删、改、查中的三种,下面的代码就是实现删的,删除一个contacts相对来说比较简单些。

 

 

       String where = ContactsContract.Data._ID + " = ? ";
    	String[] params = new String[] {android_id};
 
        ArrayList ops = new ArrayList();
        ops.add(ContentProviderOperation.newDelete(ContactsContract.RawContacts.CONTENT_URI)
    	        .withSelection(where, params)
    	        .build());
        try {
		cr.applyBatch(ContactsContract.AUTHORITY, ops);
	} catch (RemoteException e) {
		// TODO Auto-generated catch block
		e.printStackTrace();
	} catch (OperationApplicationException e) {
		// TODO Auto-generated catch block
		e.printStackTrace();
	}

删除一个contacts有很多的选择,你可以只删除电话这一块,也可以删除联系人信息这一块,而且你不仅可以将id做作为条件进行删除,你也可以将联系电话做为条件进行删除,你也还可以以用户名做为条件进行删除。

以上代码便可以实现对android contacts的增、删、改、查等操作。最后不要忘了赋予APP 对contacts读写的权限:

分享到:
评论

相关推荐

    电子通信录ASP.NET2.0+SQL2005

    在本项目中,开发者可能创建了一个数据库表来存储联系人的姓名、电话、电子邮件等信息,并通过ADO.NET接口与ASP.NET应用程序进行交互,实现数据的增删改查功能。 电子通信录的主要功能可能包括: 1. 用户注册与...

    一个基于C#+ASP.NET实现的通讯录管理系统2.0源码例子

    系统的核心功能包括用户注册、登录、联系人信息的增删改查以及头像上传等。通过这些功能,用户可以方便地维护他们的联系人数据,实现电子化、便捷化的通讯录管理。 【标签】:“通讯录管理”标签表明了该系统的主题...

    网上报名系统 v2.0-ASP源码.zip

    在ASP中,开发者可以通过VBScript或JScript编写脚本,与服务器上的各种数据库进行交互,实现数据的增删改查。在这个"网上报名系统 v2.0"中,我们可以推测它包含了用户注册、登录、填写报名信息、提交报名表单等功能...

    人力资源管理系统需求规格说明书V2.0.doc

    业务员能进行增删改查操作,并记录操作过程。 - **合同审核**:合同新增后需经过指定人员审核才能生效,确保合同的合法性。 - **合同续签与终止**:系统支持合同到期前的续签和根据需要的终止操作。 - **合同到期...

    UCenter Home v2.0 繁体中文BIG5.zip

    相比 UCenter Home 1.5 正式版,2.0 正式版拥有以下重要更新功能: 投票 新增投票基础应用。 除一般常用投票功能外,还具有悬赏投票、限制男女投票、评论限制、投票截止日期等功能选项; 活动 新增活动基础应用...

    ASP.NET2.0+SQL2005项目开发.rar

    2. **通讯录**:这个示例可能包含了用户管理联系人信息的功能,使用ASP.NET的表单验证、数据绑定和存储过程来实现数据的增删改查操作。 3. **选课系统**:该应用可能涉及到学生选课、课程管理等功能,展示如何处理...

    UCenter Home v2.0 繁体中文UTF-8.zip

    相比 UCenter Home 1.5 正式版,2.0 正式版拥有以下重要更新功能: 投票 新增投票基础应用。 除一般常用投票功能外,还具有悬赏投票、限制男女投票、评论限制、投票截止日期等功能选项; 活动 新增活动基础应用...

    UCenter Home 2.0 繁体中文UTF8.zip

    新增的表态功能,让用户动动鼠标,就能参与互动,人与人的沟通变得更加快捷; 日志、图片、话题等基础应用中,全部引入表态功能。 站长可以对表态进行添加、删除,并可自定义动作名称、图片、顺序等。 道具 新增...

    简易通讯录源码

    这里我们探讨的是一款名为“ContactBook-2.0-master”的简易通讯录源码,它提供了基础的增删改查功能,以及头像修改和一点拨号等实用特性。下面将对这款通讯录的实现原理、功能模块和设计思路进行深入解析。 首先,...

    asp.net 2.0管理系统开发(C#)经典案例酒店管理系统源码

    数据访问层则负责与数据库进行交互,执行SQL语句,完成数据的增删改查操作。 二、旅客信息管理 旅客信息管理模块是系统的核心部分,用于记录和管理入住酒店的旅客信息,包括姓名、联系方式、身份证号、入住时间、退...

    AddressBook

    开发者可能使用了ADO.NET,这是.NET框架的一部分,用于连接和交互数据库,实现了数据的增删改查操作。 软件架构可能包含以下组件: 1. 用户界面:使用Windows Forms设计,提供各种控件如文本框、下拉列表和按钮,...

    UCenter Home v2.0 简体中文GBK.zip

    相比 UCenter Home 1.5 正式版,2.0 正式版拥有以下重要更新功能: 投票 新增投票基础应用。 除一般常用投票功能外,还具有悬赏投票、限制男女投票、评论限制、投票截止日期等功能选项; 活动 新增活动基础应用...

    UCenter Home v2.0 简体中文 GBK.zip

    相比 UCenter Home 1.5 正式版,2.0 正式版拥有以下重要更新功能: 投票 新增投票基础应用。 除一般常用投票功能外,还具有悬赏投票、限制男女投票、评论限制、投票截止日期等功能选项; 活动 新增活动基础应用...

    UCenter Home 2.0 简体中文GBK.zip

    新增的表态功能,让用户动动鼠标,就能参与互动,人与人的沟通变得更加快捷; 日志、图片、话题等基础应用中,全部引入表态功能。 站长可以对表态进行添加、删除,并可自定义动作名称、图片、顺序等。 道具 新增...

    UCenter Home v2.0 繁体中文 BIG5.zip

    相比 UCenter Home 1.5 正式版,2.0 正式版拥有以下重要更新功能: 投票 新增投票基础应用。 除一般常用投票功能外,还具有悬赏投票、限制男女投票、评论限制、投票截止日期等功能选项; 活动 新增活动基础应用...

    狂龙通讯录管理系统09牛年版

    1. 数据管理:可能增强了联系人信息的增删改查功能,使得用户能更方便地管理大量联系人信息,包括姓名、电话、邮箱、地址等详细资料。 2. 分类与搜索:可能增加了对联系人进行分类的功能,比如家庭、工作、朋友等,...

    UCenter Home 2.0 简体中文UTF8.zip

    新增的表态功能,让用户动动鼠标,就能参与互动,人与人的沟通变得更加快捷; 日志、图片、话题等基础应用中,全部引入表态功能。 站长可以对表态进行添加、删除,并可自定义动作名称、图片、顺序等。 道具 新增...

    UCenter Home v2.0 简体中文UTF-8.zip

    相比 UCenter Home 1.5 正式版,2.0 正式版拥有以下重要更新功能: 投票 新增投票基础应用。 除一般常用投票功能外,还具有悬赏投票、限制男女投票、评论限制、投票截止日期等功能选项; 活动 新增活动基础应用...

    UCenter Home v2.0 繁体中文 UTF-8.zip

    相比 UCenter Home 1.5 正式版,2.0 正式版拥有以下重要更新功能: 投票 新增投票基础应用。 除一般常用投票功能外,还具有悬赏投票、限制男女投票、评论限制、投票截止日期等功能选项; 活动 新增活动基础应用...

    通讯录源码

    在编程领域,通讯录系统通常涉及到数据存储、查询、增删改查(CRUD)等核心功能,对于学习和理解用户管理、数据库交互以及可能的界面设计有很好的实践价值。下面我们将深入探讨这个主题中的关键知识点。 首先,**...

Global site tag (gtag.js) - Google Analytics