取今天过生日的联系人

时间:2014-10-07 14:03:05

标签: android sqlite android-sqlite

我想获取今天有生日(即当天)的联系人的信息。以下是我的计划。  它在上个月测试时工作正常,但现在它没有返回正确的数据。

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为空。有人可以指出我在逻辑中犯的错误。

感谢。

1 个答案:

答案 0 :(得分:1)

错误在于你处理月份值的地方。由于十月等于9,你最终会得到字符串“%-9-08”。

您可以添加更多逻辑来处理这种情况,但这实际上不是执行这些操作的正确方法。 试试这个:

String date = "'%-" + DateFormat.format("MM-dd",cal).toString() + "'";