使用FTP搜索延迟检索父文档

时间:2014-03-10 10:21:47

标签: java lotus-notes lotus-domino lotus domino-designer-eclipse

我在$ message id字段上使用FT搜索来检索父文档。我的数据库是FT索引的。我需要父文件来接受会议邀请。如何在获得会议邀请2小时后能够检索文档。需要帮助。

String messageiD="<OFF0E85FF0.91FEF356-ON65257C97.00360343-65257C97.00361318@LocalDomain>";
 if (messageiD.contains("@")) {
                String[] strArr = messageiD.split("@");
                 messageiD = strArr[0].replace("<", "");
                 System.out.println("message id is "+messageiD);
                //return messageiD;
            }

            String qry = "Field $MessageID CONTAINS " + messageiD;
            DocumentCollection col1 = m_database.FTSearch(qry);
            System.out.println("doc col length is " +col1.getCount());
            Document docOld = col1.getFirstDocument();
            System.out.println(docOld.getNoteID());

1 个答案:

答案 0 :(得分:2)

如果您能够在一小时/两小时后检索结果,那么FT-Index在尝试处理您的请求时不是最新的。使用NotesDatabase-类的方法updateFTIndex()来确保它是最新的。当然,如果它是最新的,你可以使用getLastFTIndexed() - 方法...这里是Designer-帮助的示例代码,使用这两种方法:

 try {
  Session session = getSession();
  AgentContext agentContext = 
      session.getAgentContext();
  // (Your code goes here) 
  Database db = agentContext.getCurrentDatabase();
  String title = db.getTitle();
  DateTime lastDT = db.getLastFTIndexed();
  DateTime nowDT = session.createDateTime("Today");
  nowDT.setNow();
  int daysSince = 
      nowDT.timeDifference(lastDT) / 86400;
  if (daysSince > 2) {
    System.out.println("Database \"" + title +
            "\" was last full-text indexed " + 
             daysSince + " days ago");
    System.out.println("Updating");
    db.updateFTIndex(true); }
  else
    System.out.println("Database \"" + title +
         "\" was full-text indexed less 
          than two days ago");

} catch(Exception e) {
  e.printStackTrace();
}

其他信息:为您定义的数据库创建全文索引时,此索引的更新频率。

但是:即使在对话框中选择“立即”,这也不意味着索引将始终是最新的。更新全文是服务器的Update-任务的一项工作。如果此任务“忙”,则请求将排队并可能会延迟一段时间,直到有可用于执行作业的资源为止。

服务器管理员可以通过设置notes.ini-变量“UPDATE_FULLTEXT_THREAD”来增强全文索引更新的性能(请参阅this link about the variable以查看详细信息)。