raw contact子表数据查询

RAW_CONTACT子表的查询很有意思。
RAW_CONTACT子表有很多。主要的有:
android.provider.ContactsContract.CommonDataKinds.StructuredName;
android.provider.ContactsContract.CommonDataKinds.Phone;
android.provider.ContactsContract.CommonDataKinds.Email;
android.provider.ContactsContract.CommonDataKinds.Organization;
我们可以通过以下形式来进行查询
//Setourexpandablelistadapter
String[]projection=newString[]{
Phone._ID,
Phone.DISPLAY_NAME,
Phone.NUMBER,
Phone.RAW_CONTACT_ID,
};

CursorcontactData=managedQuery(
Phone.CONTENT_URI,
null,//这里是查询所有的列。可以用projection代替来进行指定查询
null,
null,
null);
我用下面的语句打印出查询到所有列名
(注意用Email查询出的列一样,说明不同子表查的列数量一样,只是在DATA1到DATA15的意义不同)
intcolCount=contactData.getColumnCount();
for(inti=0;i<colCount;i++)
Log.i(TAG,i+"i:"+contactData.getColumnName(i));
但打印出来的列比我想象的多很多。我想Phone.CONTENT_URI是对应数据库的“视图”概念
查询所得一共有55列
一、子表本身数据,ContactsContract.Data中声明的25个列:
变量名列名备注
_ID_id
MIMETYPEmimetype
RAW_CONTACT_IDraw_contact_id
IS_PRIMARYis_primary
IS_SUPER_PRIMARYis_super_primary
DATA_VERSIONdata_version
DATA1~DATA15data1~data15
SYNC1~SYNC4data_sync1~data_sync4

二、和ContactsContract.StatusUpdates连接,所得的6项数据
变量名列名备注
PRESENCEmodePRESENCE_STATUS变量也是“mode”,但按照Data的文档是PRESENCE
STATUSstatusPRESENCE_CUSTOM_STATUS变量也是“mode”,但按照Data的文档应该是STATUS
STATUS_TIMESTAMPstatus_ts
STATUS_RES_PACKAGEstatus_res_package
STATUS_LABELstatus_label
STATUS_ICONstatus_icon
注意1:其实PRESENCE_STATUS和PRESENCE_CUSTOM_STATUS并没有在StatusUpdates申明的列当中。当然也就不可能被连接进来。
注意2:StatusUpdates共有11项数据,但还有5项数据没被连接进来。
他们是DATA_ID,PROTOCOL,CUSTOM_PROTOCOL,IM_HANDLE,IM_ACCOUNT。

三、连接RawContacts所得的11项目数据。
变量名列名备注
CONTACT_IDcontact_id
TIMES_CONTACTEDtimes_contacted
LAST_TIME_CONTACTEDlast_time_contacted
STARREDstarred
CUSTOM_RINGTONEcustom_ringtone
SEND_TO_VOICEMAILsend_to_voicemail
ACCOUNT_NAMEaccount_name
ACCOUNT_TYPEaccount_type
SOURCE_IDsourceid
VERSIONversion
DIRTYdirty
注意1:虽然RawContacts共拥有18项数据,但这里只包含了11项目。还有7项没被包含进来。
他们分别是_ID,AGGREGATION_MODE,DELETED,SYNC1~SYNC4
注意2:RawContactsColumns一共定义的三项目数据,但是只有一项CONTACT_ID被包含进来。
AGGREGATION_MODE和DELETED没有被包含进来
按照ContactsContract.Data中的文档,只有CONTACT_ID,AGGREGATION_MODE,DELETED三项会被包含来的啊。
但实际并非如此。WHY?

四、连接Contacts所得的9项目数据。
变量名列名备注
LOOKUP_KEYlookup
PHOTO_IDphoto_id
IN_VISIBLE_GROUPin_visible_group
CONTACT_PRESENCEcontact_presence
ONTACT_STATUScontact_status
CONTACT_STATUS_TIMESTAMPcontact_status_ts
CONTACT_STATUS_RES_PACKAGEcontact_status_res_package
CONTACT_STATUS_LABELcontact_status_label
CONTACT_STATUS_ICONcontact_status_icon
注意1:虽然RawContacts共拥有17项数据,但这里只包含了9项目。还有8项没被包含进来。
他们分别是:_ID,NAME_RAW_CONTACT_ID,DISPLAY_NAME_PRIMARY,TIMES_CONTACTED,
LAST_TIME_CONTACTED,STARRED,CUSTOM_RINGTONE,SEND_TO_VOICEMAIL
注意2:在RawContacts和Contacts中都有一个名叫TIMES_CONTACTED的变量名,且他们的列名都为“times_contacted”。
参照TIMES_CONTACTED在两个类的中的定义,
Contacts中TIMES_CONTACTED值为Contacts组中所有RawContacts的TIMES_CONTACTED值的最大值。
所以查询所得名叫times_contacted的列应该是对于RawContacts的TIMES_CONTACTED。
LAST_TIME_CONTACTED同理。
注意3:STARRED参照定义也可知查询所得名叫STARRED的列应该是对于RawContacts的STARRED。
注意4:对于CUSTOM_RINGTONE和SEND_TO_VOICEMAIL,在RawContacts和Contacts的列中都有对他们的申明,且它们的定义也相同。
参照它们的定义文档来看也不是很清楚。
但我们这里主要是针对RawContacts的查询,我想他们应该是来自于RawContacts,而不是Contacts。
注意5:对于TIMES_CONTACTED,LAST_TIME_CONTACTED,STARRED,CUSTOM_RINGTONE,SEND_TO_VOICEMAIL
然参照ContactsContract.Data文档他们是被Contacts连接进来,
但通过以上分析,他们没有Contact连接进来。而是通过RawContacts连接进来。

五、Data.GroupMembership的一项数据。
变量名列名备注
GROUP_SOURCE_IDgroup_sourceid
这个数据应该是通过连接Data.GroupMembership所得的。但是文档中并没说明
六,未确定来源数据2项
列名备注
display_name
res_package
注意1:display_name可能来自ContactsColumns的DISPLAY_NAME,及来自于Conact.
但关于Conact的DISPLAY_NAME来自于数据库的哪里还是puzzle.可能来自于DISPLAY_NAME_PRIMARY。
为什么不能直接查询Contacts的DISPLAY_NAME_PRIMARY?也是个puzzle.
注意2:res_package来自哪里?没任何线索。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
LabVIEW是一款强大的图形化编程软件,用于数据采集和处理。在LabVIEW中,可以使用不同的方式读取raw格式数据。 第一种方法是使用File I/O函数,通过打开文件、读取数据和关闭文件的操作来读取raw格式数据。可以使用"Open/Create/Replace File"函数打开要读取的raw文件,然后使用"Read from Binary File"函数来读取数据,最后使用"Close File"函数关闭文件。 第二种方法是使用NI-DAQmx驱动进行数据采集。可以使用"DAQmx Create Task"函数创建任务,设置任务的采样率、采样点数等参数,然后调用"DAQmx Read"函数读取raw数据。这个方法适用于需要实时采集数据的情况。 第三种方法是使用第三方工具包。LabVIEW有许多第三方工具包可以用于读取各种格式的数据,包括raw格式数据。你可以在LabVIEW的官方网站或者其他相关资源网站上搜索并下载适用于读取raw数据的工具包,然后在LabVIEW中安装和使用。 无论使用哪种方法,都需要注意raw数据的格式和字节顺序。因为raw数据是未经处理的二进制数据,可以是任意格式和字节顺序。在读取raw数据之前,需要确定raw数据的格式和字节顺序,然后按照相应的规则进行解析和处理。 总之,LabVIEW提供了多种方式来读取raw格式数据,你可以根据具体的需求选择适合的方法。无论使用哪种方法,都需要注意raw数据的格式和字节顺序,在数据采集和处理过程中保证数据的准确性和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值