Получить сегодняшние записи календаря в Lotus Notes, используя Java - PullRequest
1 голос
/ 03 октября 2009

Я пытаюсь получить записи календаря на определенный день. Код работает без ошибок, но я получаю неправильную запись календарной даты. Я уверен, что формула верна, но тем не менее буду признательна за любую помощь в этом. Вот код.

        long startTime;
        long endTime;
        String searchFormula;
        DocumentCollection dc_CalendarEntries;

        System.out.println("Getting default TimeZone");
        TimeZone calTZ = TimeZone.getDefault();
        GregorianCalendar startDay = new GregorianCalendar(calTZ);
        startDay.set(startDay.get(1), startDay.get(2), startDay.get(5), 0, 0, 0);
        startTime = startDay.getTime().getTime();
        GregorianCalendar endDay = new GregorianCalendar(calTZ);
        endDay.setTime(startDay.getTime());
        endDay.add(5, 1);
        endTime = endDay.getTime().getTime();
        System.out.println("Creating Search Formula");

        StringBuffer searchFormulaStringBuffer = new StringBuffer("@IsAvailable(CalendarDateTime)");
        searchFormulaStringBuffer.append(" & StartDateTime >= @Date(").append(startDay.get(1)).append("; ").append(startDay.get(2) + 1).append("; ").append(startDay.get(5)).append("; ").append(startDay.get(10)).append("; ").append(startDay.get(12)).append("; ").append(startDay.get(13)).append(")");
        searchFormulaStringBuffer.append(" & EndDateTime <= @Date(").append(endDay.get(1)).append("; ").append(endDay.get(2) + 1).append("; ").append(endDay.get(5)).append("; ").append(endDay.get(10)).append("; ").append(endDay.get(12)).append("; ").append(endDay.get(13)).append(")");
        searchFormulaStringBuffer.append(" & (AppointmentType = \"3\" | AppointmentType = \"0\")");
        searchFormula = searchFormulaStringBuffer.toString();           
        System.out.println(searchFormula);
        dc_CalendarEntries = db_Mail.search(searchFormula); 

Вот какая формула применяется.

@IsAvailable(CalendarDateTime) & StartDateTime >= @Date(2009; 10; 3; 0; 0; 0) & EndDateTime <= @Date(2009; 10; 4; 0; 0; 0) & (AppointmentType = "3" | AppointmentType = "0")

Я получаю следующие записи.

Test Project daily checkpoint 2009-09-08
This is a Test Meeting 2009-10-03

Вторая запись верна и в порядке, но по какой-то странной причине первая запись продолжает появляться независимо от даты, которую я предоставляю. Я не уверен, является ли это проблемой кодирования или какой-либо проблемой конфигурации в моих заметках.

1 Ответ

2 голосов
/ 05 октября 2009

Необходимо соблюдать осторожность при повторении записей календаря, поскольку они будут иметь значения полей начала и конца даты и времени, которые соответствуют первой записи серии.

...