使用KeywordQuery在搜索结果中返回错误的DateTime

时间:2017-02-27 20:06:46

标签: sharepoint sharepoint-2013 sharepoint-search

我有一个大问题。我在服务器端代码中使用KeywordQuery从具有相同contenttypeid的多个列表中返回项目。我在这些列表中有一些日期时间列。当我从keywordwquery搜索中返回值时,我得到

3/2/2017 11:00:00 PM

但是我在列表项目中保存了3月3日作为日期!这有什么不对?为什么我总是从搜索数据库收到日期 - 1小时,我如何在服务器端代码中更正此信息?

这是我的代码:

            SearchServiceApplicationProxy proxy = (SearchServiceApplicationProxy)SearchServiceApplicationProxy.GetProxy(SPServiceContext.GetContext(querySite));

            using (KeywordQuery keywordQuery = new KeywordQuery(proxy))
            {
                try
                {
                    keywordQuery.ResultsProvider = SearchProvider.Default;
                    keywordQuery.StartRow = 0;
                    keywordQuery.RowLimit = 9999;
                    keywordQuery.EnableStemming = false;
                    keywordQuery.TrimDuplicates = false;
                    keywordQuery.AuthenticationType = QueryAuthenticationType.PluggableAuthenticatedQuery;
                    keywordQuery.KeywordInclusion = KeywordInclusion.AllKeywords;

                    keywordQuery.QueryText = "contentclass:\"STS_ListItem_Task\" NOT ContentTypeId:\"0x010800C140B62AF5566C4CBFC76C53B8D4DA94\"";

                    keywordQuery.SelectProperties.Add("Author");
                    keywordQuery.SelectProperties.Add("AssignedTo");
                    keywordQuery.SelectProperties.Add("DueDate");
                    keywordQuery.SelectProperties.Add("StartDate");
                    keywordQuery.SelectProperties.Add("path");
                    keywordQuery.SelectProperties.Add("title");

                    SearchExecutor executor = new SearchExecutor();
                    ResultTableCollection resultTableCollection = executor.ExecuteQuery(keywordQuery);
                    var resultTables = resultTableCollection.Filter("TableType", KnownTableTypes.RelevantResults);
                    ResultTable resultTable = resultTableCollection.FirstOrDefault();

                    if (resultTable.Table.Rows.Count > 0)
                    {
                       ...
                    }
                }
                catch (Exception ex)
                {

                }
            }

1 个答案:

答案 0 :(得分:0)

我相信这是在这里发挥作用的时区转变。检查哪个时间是本地时间,哪个是UTC。