一.联系人和通话记录: 数据库文件/data/data/com.android.providers.contacts/databases/contacts2.db
  通话记录的数据存在calls表中; 联系人数据存放在raw_contacts和data表里,两个表构成主从表关系.
  
    1.联系人(contacts2.db)
     每个联系人在raw_contacts表里有一条记录,但地址\名称\email\电话等等数据存放在data表中.
     (1)mimetypes表
      _id mimetype
      1 vnd.android.cursor.item/email_v2
      2 vnd.android.cursor.item/im
      3 vnd.android.cursor.item/nickname
      4 vnd.android.cursor.item/organization
      5 vnd.android.cursor.item/phone_v2
      6 vnd.android.cursor.item/sip_address
      7 vnd.android.cursor.item/name
      8 vnd.android.cursor.item/postal-address_v2
      9 vnd.android.cursor.item/identity
      10 vnd.android.cursor.item/photo
      11 vnd.android.cursor.item/group_membership
      12 vnd.android.cursor.item/website
      13 vnd.android.cursor.item/note
     
     (2)data表
      字段列表:_id package_id mimetype_id raw_contact_id is_read_only is_primary is_super_primary data_version data1 data2 data3 data4 data5 data6 data7 data8 data9 data10 data11 data12 data13 data14 data15 data_sync1 data_sync2 data_sync3 data_sync4
      raw_contact_id:此值对应raw_contacts表的_id值.data表中每个联系人会有多行数据,同一个联系人而言,此值是相同的.
      mimetype_id:对应mimetypes表的类型.由mimetypes表可知,data表中的数据,如果mimetype_id值为7表示存的是姓名,5表示存的是号码.
      其它信息需要根据mimetype_id指示的类型具体分析
      姓名数据:Uri(content://com.android.contacts/data)
      Uri对应的宏为:android.provider.ContactsContract.Data.CONTENT_URI
       data1字段: 姓名完整名称
       data2字段: 名GIVEN_NAME
       data3字段: 姓FAMILY_NAME
       data4字段: 姓名前缀PREFIX
       data5字段: 中间名MID_NAME
       data6字段: 姓名后缀SUFIX
       data7字段: 名字拼音SUFIX_PINYIN
       data8字段: 中间名拼音MID_PINYIN
       data9字段: 姓氏拼音FAMILY_NAME_PINYIN
      电话数据:Uri(content://com.android.contacts/data/phones)
      Uri对应的宏为:android.provider.ContactsContract.CommonDataKinds.Phone.CONTENT_URI
       data1字段: 完整的电话号码
       data2字段: 电话类型
       电话类型信息如下
        TYPE_CUSTOM = 0;
        TYPE_HOME = 1;
        TYPE_MOBILE = 2;
        TYPE_WORK = 3;
        TYPE_FAX_WORK = 4;
        TYPE_FAX_HOME = 5;
        TYPE_PAGER = 6;
        TYPE_OTHER = 7;
      Email数据:Uri(content://com.android.contacts/data/emails)
      Uri对应的宏为:android.provider.ContactsContract.CommonDataKinds.Email.CONTENT_URI
       data1字段: 邮箱地址
       data2字段: Email类型
        Email类型信息如下
        TYPE_CUSTOM = 0;
        TYPE_HOME = 1;
        TYPE_WORK = 2;
        TYPE_OTHER = 3;
        TYPE_MOBILE = 4;
      地址数据:Uri(content://com.android.contacts/data/postals)
       data2字段: 地址类型
       data4字段: 街道
       data7字段: 州
       data8字段: 城市
       data9字段: 邮政编码
       地址类型信息如下
        TYPE_CUSTOM = 0;
        TYPE_HOME = 1;
        TYPE_WORK = 2;
        TYPE_OTHER = 3; 
     
     (3)raw_contacts表
      _id字段:每行表示一个联系人,与data表raw_contact_id字段对应.
      sort_key字段:表示了姓名排序的信息.中文有对应的拼音.可能显示的数据格式为:LI 李 CUN 村

2.通话记录(contacts2.db)
     Uri(content://call_log/calls) 对应的宏为:android.provider.CallLog.Calls.CONTENT_URI
     name字段: 联系人姓名 CallLog.Calls.CACHED_NAME
     number字段:电话号码 CallLog.Calls.NUMBER
     date字段: 日期 CallLog.Calls.DATE
     type字段: 类型 CallLog.Calls.TYPE
     duration字段: 通话时长 CallLog.Calls.DURATION

Android数据库资料的更多相关文章

  1. 10分钟理解Android数据库的创建与使用(附具体解释和演示样例代码)

    1.Android数据库简单介绍. Android系统的framework层集成了Sqlite3数据库.我们知道Sqlite3是一种轻量级的高效存储的数据库. Sqlite数据库具有以下长处: (1) ...

  2. 深入解析Sqlite的完美替代者,android数据库新王者——Realm

    写在前面: 又到一年一度七夕虐狗节,看着大家忍受着各种朋友圈和QQ空间还有现实生活中的轮番轰炸,我实在不忍心再在这里给大家补刀,所以我觉得今天不虐狗,继续给大家分享有用的. 如果你比较关心androi ...

  3. [Android Pro] 完美Android Cursor使用例子(Android数据库操作)

    reference to : http://www.ablanxue.com/prone_10575_1.html 完美 Android Cursor使用例子(Android数据库操作),Androi ...

  4. Android 数据库框架OrmLite的使用(一)

    在这里记录下最基本的用法,官网上可了解相关的介绍. 1.下载OrmLite jar 在下载android的:ormlite-android-4.48.jar和ormlite-core-4.48.jar ...

  5. Android数据库升级

    随着Android应用版本的迭代,经常遇到数据库表结构发生改变,或者一些指定的表数据需要更新.这也就引出一个问题Android数据库的更新问题. Android数据库升级分类 Android数据库更新 ...

  6. [转]Android 学习资料分享(2015 版)

    转 Android 学习资料分享(2015 版) 原文地址:http://www.jianshu.com/p/874ff12a4c01 目录[-] 我是如何自学Android,资料分享(2015 版) ...

  7. 优雅的处理Android数据库升级的问题

    原始完成于:2015-04-27 19:28:22 提供一种思路,优雅的处理Android数据库升级的问题,直接上代码: 1 package com.example.databaseissuetest ...

  8. 【Android开发资料分享】自己整理的Android开发资料,非常全面

    学习Android以来,不知不觉中收集了大量非常优秀的Android开发资料,一直没有系统的整理,最近抽时间把收藏夹中的资料做了一下整理,现在分享给大家,希望能够帮助到需要的人.这份资料我还会不断的更 ...

  9. 我是如何自学Android,资料分享(2015 版)

    自己学了两三个月的Android,最近花了一周左右的时间写了个App——Diigoer(已开源),又花了一两周时间找工作,收到了两个Offer,也算是对自己学习的一种认可吧:我刚开始学习总结的——&l ...

随机推荐

  1. Python全栈 进阶(进阶内容都在这了)

    原文地址 https://yq.aliyun.com/articles/632754?spm=a2c4e.11155435.0.0.23eb3312feB6dG ................... ...

  2. [SHELL]退出脚本

    一,退出状态码 1,范围:0~255 2,查看退出状态码:必须在命令执行之后立即执行 ,显示的是脚本最后一条命令的退出状态码 echo $? 若f返回值为0,则表示正常 有异常为正值 二,exit 脚 ...

  3. 【转】《王者荣耀》技术总监复盘回炉历程:没跨过这三座大山,就是另一款MOBA霸占市场了

    如今已经大获市场成功的<王者荣耀>一直是业内各方关注的对象,而我们也知道这款产品在成为国民级游戏之前,也遇到过一段鲜有人知的调优期.也就是在2015年8月18号正式不删档测试版本推出之后, ...

  4. 使用bing或google来翻译网页

    google代码:在</head>之后插入 <meta name="google-translate-customization" content="4 ...

  5. 今日头条 2018 AI Camp 5 月 26 日在线笔试编程题第一道——最佳路径

    题目 给定一个 n*m 的矩阵 A ,矩阵中每一个元素为一个十六进制数.寻找一条从左上角都右下角的路径,每次只能向右或者向下移动, 使得路径上所有数字之积在 16 进制下的后缀 0 最少. 输入描述: ...

  6. centos+nginx+redmine+gitosis安装指南

    说明 这篇文章我现在的主要目的是记录自己安装redmine和gitosis的过程,可能写的有些糙,请各位读者见谅.我会在后面的时间里逐渐完善细节.但我想,这已经是网上迄今为止国内最详细的nginx+r ...

  7. Centos6设置DNS

    通过编辑 vi /etc/resolv.conf 设置首选DNS和次要DNS.如下,排在前面的就是首选DNS,后面一行就是次要的DNS服务器DNS vi /etc/resolv.conf namese ...

  8. The Uncle_b's First Love

    Description ACM成立大会之后,uncle_b被其中一个大一女孩深深地吸引,但腼腆的B叔又不知道如何去表达自己内心的想法,经calmound神的指导,B叔决定写封情书给对方.他从Tamar ...

  9. “Hello world!”团队—文案+美工

    ★★★本次采访我们随机选取5位不同的潜在用户,随机选取地点进行了本次采访. (一)项目有关内容: 大家好,我们是Hello World团队.我们组目前正在开发一个飞机大战的小游戏大家应该在小时候都玩过 ...

  10. 团队选题报告(i know)

    一.团队成员及分工 团队名称:I know 团队成员: 陈家权:选题报告word撰写 赖晓连:ppt制作,原型设计 雷晶:ppt制作,原型设计 林巧娜:原型设计,博客随笔撰写 庄加鑫:选题报告word ...