我有从 Lotus Notes Domino 服务器查询日历条目的 Java 代码(基于开始和结束日期范围)。下面是代码的简化版本。
当查询日期格式与本地客户端相同的 Domino 服务器时,一切都很好,例如服务器和客户端都使用 m/d/y 格式。但是,如果服务器和客户端使用不同的格式(例如,服务器使用美国格式 m/d/y,客户端使用德语格式 d/m/y),则会发现错误数量的 Lotus Notes 条目。
这是因为我使用 getLocalTime() 将日期转换为本地字符串,然后使用 @TextToTime() 创建日期范围。
有没有办法找出服务器使用的日期格式?或者有没有办法完全避免日期到字符串的转换?我想传入两个 Lotus DateTime 对象,让服务器根据需要对它们进行解码。
import lotus.domino.*;
Session session = NotesFactory.createSession((String)null, (String)null, password);
Database db = session.getDatabase(dominoServer, mailfile, false);
// Get our start and end query dates in Lotus Notes format. We will query
// using the localized format for the dates.
lotus.domino.DateTime minStartDateLN = session.createDateTime(minStartDate);
lotus.domino.DateTime maxEndDateLN = session.createDateTime(maxEndDate);
// Query Lotus Notes to get calendar entries in our date range.
// Here is an overview of this SELECT:
// @IsAvailable(CalendarDateTime) is true if the LN document is a calendar entry
// @Explode splits a string based on the delimiters ",; "
// The operator *= is a permuted equal operator. It compares all entries on
// the left side to all entries on the right side. If there is at least one
// match, then true is returned. Explode is used because the CalendarDateTime
// field can have many dates separated by ";" (e.g. for recurring meetings).
String calendarQuery = "SELECT (@IsAvailable(CalendarDateTime) & (@Explode(CalendarDateTime) *= @Explode(@TextToTime(\""
+ minStartDateLN.getLocalTime()
+ "-" + maxEndDateLN.getLocalTime() + "\"))))";
DocumentCollection queryResults = db.search(calendarQuery);