我想获取今天(即当天)有生日的联系人的信息。下面是我的程序。
我上个月测试时它工作正常,但是现在它无法返回正确的数据。
Uri uri = ContactsContract.Data.CONTENT_URI;
String[] projection = new String[] {
ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME,
ContactsContract.CommonDataKinds.Event.CONTACT_ID,
ContactsContract.Contacts._ID,
ContactsContract.Contacts.STARRED,
ContactsContract.Contacts.TIMES_CONTACTED,
ContactsContract.CommonDataKinds.Event.START_DATE };
Calendar cal = Calendar.getInstance();
int month = cal.get(Calendar.MONTH);
int day = cal.get(Calendar.DATE);
String date = "'%-" + (month > 8 ? month : "0" + (month + 1)) + "-"
+ (day > 9 ? day : "0" + day) + "'";
String where = ContactsContract.Data.MIMETYPE + "= ? AND "
+ ContactsContract.CommonDataKinds.Event.TYPE + " IN ( "
+ ContactsContract.CommonDataKinds.Event.TYPE_BIRTHDAY
+ " ) AND "
+ ContactsContract.CommonDataKinds.Event.START_DATE + " LIKE "
+ date;
String[] selectionArgs = new String[] { ContactsContract.CommonDataKinds.Event.CONTENT_ITEM_TYPE };
String sortOrder = ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME;
Cursor c=mContext.getContentResolver().query(uri, projection, where,
selectionArgs, sortOrder);
我的光标c为空。有人可以指出我在逻辑上犯的错误。
谢谢。
最佳答案
错误是您处理月份值的地方。由于十月等于9,因此您将以字符串“%-9-08”结尾。
您可以添加更多逻辑来处理这种情况,但这实际上不是正确的方法。
尝试这个:
String date = "'%-" + DateFormat.format("MM-dd",cal).toString() + "'";