通讯录数据库分析
在通讯录这个应用里有个特别重要的三个表,分别为:raw_contacts、data、mimetype。
1、raw_contacts表保存联系人的ID 例如:contact_id = 0;
2、data表保存联系人的数据,字段data1存放数据,mimetype_id 存放数据类型,raw_contacts_id字段表示保存数据属于那个人联系人的
3、mimetype表保存数据类型 ,字段mimetype_id = 1 代表email,mimetype_id = 5 代表phone, mimetype_id = 7 代表name
其中通讯录中显示的手机号存放在data表中,而对应的用户显示名称却是在raw_contacts中,所以当我们要去获取手机号对应的用户显示名称的时候,我们还需要去查看raw_contacts表中的值,这个中间对应的桥梁就是data表中raw_contact_id。
raw_contacts是三个表的基础,他的_ID列与data表中的raw_contacts_id关联。
相关uri
在安卓系统中,关于通讯录的URI都已经预先解析完毕,其结果都被当作常量,存在源码里。
例如 “content://com.android.contacts/raw_contacts”,被解析为
ContactsContract.RawContacts.CONTENT_URI
其中ContactsContract.RawContacts指的是raw_contacts表,常量CONTENT_URI为解析出来的结果。
增删改查
查询
1.获取raw_contacts表中的contact_id的所有值,返回的cursor对象中会包含与id相关联的其他两表的信息
2.遍历cursor对象。
注意:在查询输出的时候,使用DISPLAY_NAME列名。在添加或者修改时,传入的是GIven_NAME列
Cursor cursor = resolver.query(ContactsContract.RawContacts.CONTENT_URI, null, null,
null);
while (cursor.moveToNext()) {
//新建一个Bean来存储数据
ContactBean bean = new ContactBean();
int id = cursor.getInt(cursor.getColumnIndex(ContactsContract.RawContacts._ID));
String name = cursor.getString(cursor.getColumnIndex(ContactsContract.Data.DISPLAY_NAME));
//一个用户的手机号可能有多个,故手机号是一个集合。,取第一个手机号
Strin

最低0.47元/天 解锁文章
2238

被折叠的 条评论
为什么被折叠?



