Android联系人数据库介绍以及对联系人的基本操作.pptVIP

Android联系人数据库介绍以及对联系人的基本操作.ppt

  1. 1、本文档共16页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Android 联系人数据库介绍 以及对联系人的基本操作 一、 联系人数据库(1) 联系人的数据库文件的位置 /data/data/viders.contacts/databases.contacts2.db 数据库中重要的几张表 1、contacts表 该表保存了所有的手机测联系人,每个联系人占一行,该表保存了联系人的ContactID、联系次数、最后一次联系的时间、是否含有号码、是否被添加到收藏夹等信息。 2、raw_contacts表 该表保存了所有创建过的手机测联系人,每个联系人占一行,表里有一列标识该联系人是否被删除,该表保存了两个ID: RawContactID和ContactID,从而将contacts表和raw_contacts表联系起来。该表保存了联系人的RawContactID 、ContactID、联系次数、最后一次联系的时间、是否被添加到收藏夹、显示的名字、用于排序的汉语拼音等信息。 一、 联系人数据库(2) 3、 mimetypes 该表定义了所有的MimeTypeID,即联系人的各个字段的唯一标志。 一、 联系人数据库(3) 4、data表 该表保存了所有创建过的手机测联系人的所有信息,每个字段占一行 ,该表保存了两个ID: MimeTypeID和RawContactID,从而将data表和raw_contacts表联系起来。 联系人的所有信息保存在列data1至data15中,各列中保存的内容根据MimeTypeID的不同而不同。如保存号码(MimeTypeID=5)的那行数据中,data1列保存号码,data2列保存号码类型(手机号码/家庭号码/工作号码等)。 二、对联系人的基本操作(1) 这里的基本操作只是针对手机测的联系人,(U)SIM侧的联系人的操作后续介绍。 如果对联系人的基本操作,我们必须得到许可。 方法就是在AndroidManifest.xml文件中配置如下权限: uses-permission android:name=android.permission.READ_CONTACTS / uses-permission android:name=android.permission.WRITE_CONTACTS / 二、对联系人的基本操作(2) 读取联系人 分为以下步骤: 1、先读取contacts表,获取ContactsID; 2、再在raw_contacts表中根据ContactsID获取RawContactsID; 3、然后就可以在data表中根据RawContactsID获取该联系人的各数据了。 二、对联系人的基本操作(3) // 获取用来操作数据的类的对象,对联系人的基本操作都是使用这个对象 ContentResolver cr = getContentResolver(); // 查询contacts表的所有记录 Cursor cur = cr.query(ContactsContract.Contacts.CONTENT_URI, null, null, null, null); // 如果记录不为空 if (cur.getCount() 0) { // 游标初始指向查询结果的第一条记录的上方,执行moveToNext函数会判断// 下一条记录是否存在,如果存在,指向下一条记录。否则,返回false。 while (cur.moveToNext()) { String rawContactsId = ; String id = cur.getString(cur.getColumnIndex(ContactsContract.Contacts._ID)); str += ID: + id + \n; 二、对联系人的基本操作(4) // 读取rawContactsId Cursor rawContactsIdCur = cr.query(RawContacts.CONTENT_URI, null, RawContacts.CONTACT_ID + = ?, new String[]{id}, null); // 该查询结果一般只返回一条记录,所以我们直接让游标指向第一条记录 if (rawContactsIdCur.moveToFirst()) { // 读取第一条记录的RawContacts._ID列的值 rawContactsId = rawContactsIdCur.getString(rawContactsIdCur.getColumnIndex( RawContacts._ID)); } rawContactsIdCur.close

文档评论(0)

118books + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档