大佬教程收集整理的这篇文章主要介绍了android – 如何使用一个查询搜索带地址的联系人(FORMATTED_ADDRESS)?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
所以他输入了ma并将获得’marTin’,’matthews’……
他将继续垫子,只会看到’matthews’
我尝试使用如下的单个查询来实现此目的,但我始终在FORMATTED_adress字段中获取联系号码.我想我有一个JOIN问题,因为我在同一个查询中使用COntactsContract.CommonDataKinds和ContactsContract.Contacts?
public static List<ContactModel> getContactsForQuery(Context context,String query) { String[] projection = new String[] { ContactsContract.Contacts.DISPLAY_NAME,Contacts.PHOTO_THUMBNAIL_URI,ContactsContract.CommonDataKinds.StructuredPostal.FORMATTED_ADDRESS }; Uri uri = ContactsContract.CommonDataKinds.Phone.CONTENT_URI; String selection = ContactsContract.Contacts.DISPLAY_NAME + " LIKE '%" + query + "%'"; cursor cursor = context.getContentResolver().query(uri,projection,SELEction,null,null); if (cursor.moveToFirst()) { do { String name = cursor.getString(0); String thumbail = cursor.getString(1); String formattedadress = cursor.getString(2); } while (cursor.moveToNext()); }
我实际上解决了我的问题
>查询Contacts._ID,Contacts.DISPLAY_NAME
>使用COntacts._ID开始第二个查询,如下所示
cursor detailcursor = context.getContentResolver().query( ContactsContract.Data.CONTENT_URI,new String[]{ CommonDataKinds.StructuredPostal.STREET,CommonDataKinds.StructuredPostal.CITY,CommonDataKinds.StructuredPostal.POSTCODE },ContactsContract.Data.CONTACT_ID + "=? AND " + CommonDataKinds.StructuredPostal.MIMETYPE + "=?",new String[]{ String.valueOf(contactID),CommonDataKinds.StructuredPostal.CONTENT_ITEM_TYPE },null);
为了记录,这是我的工作示例.它解决了这个问题,但我仍然认为它会产生很大的负荷.在每个用户条目(afterTextchangE)上,我调用getContactsDetailsQuery,它首先获取所有用户的ID,其ID包含其名称(光标)中的查询,然后我为每个用户启动另一个查询(detailcursor)以获取地址.为了防止过载,我增加了一个限制..
public static List<SearchModel> getContactDetailsForQuery(Context context,String query,int limit) { final int CONTACT_ID_INDEX = 0; final int CONTACt_name_INDEX = 1; final int CONTACT_THUMBNAIL_INDEX = 2; //my custom model to hold my results List<SearchModel> results = new ArrayList<SearchModel>(); final String[] SELEctUser = new String[]{ Contacts._ID,Contacts.DISPLAY_NAME,Contacts.PHOTO_THUMBNAIL_URI}; String selection = Contacts.DISPLAY_NAME + " LIKE ?"; String[] SELEctionArgs = new String[]{"%" + query + "%"}; String sortOrder = Contacts.DISPLAY_NAME + " ASC"; cursor cursor = context.getContentResolver().query(Contacts.CONTENT_URI,SELEctUser,SELEctionArgs,sortOrder,null); int contactCounter = 0; if (cursor != null && cursor.moveToFirst()) { do { String contactID = cursor.getString(CONTACT_ID_INDEX); String displayName = cursor.getString(CONTACt_name_INDEX); String thumbnail = cursor.getString(CONTACT_THUMBNAIL_INDEX); //get user details with user id (this is the query i wanted to change in my question!!) cursor detailcursor = context.getContentResolver().query(ContactsContract.Data.CONTENT_URI,new String[]{ CommonDataKinds.StructuredPostal.FORMATTED_ADDRESS},ContactsContract.Data.CONTACT_ID + "=? AND " + CommonDataKinds.StructuredPostal.MIMETYPE + "=?",new String[]{String.valueOf(contactID),CommonDataKinds.StructuredPostal.CONTENT_ITEM_TYPE},null); if (detailcursor != null && detailcursor.moveToFirst()) { //special case: user has several address,query all of them do { String formattedAddress = detailcursor.getString(detailcursor.getcolumnIndex(CommonDataKinds.StructuredPostal.FORMATTED_ADDRESS)); //user has serveral adress -> init model for each adress SearchModel contact = new SearchModel(); results.add(contact); contactCounter++; } while (detailcursor.moveToNext() && contactCounter < limit); } else { //user has no adress -> init model SearchModel contact = new SearchModel(); results.add(contact); contactCounter++; } detailcursor.close(); } while (cursor.moveToNext() && contactCounter < limit); } cursor.close(); return results; }
以上是大佬教程为你收集整理的android – 如何使用一个查询搜索带地址的联系人(FORMATTED_ADDRESS)?全部内容,希望文章能够帮你解决android – 如何使用一个查询搜索带地址的联系人(FORMATTED_ADDRESS)?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。