过滤SearchResultCollection中的项目

时间:2012-09-13 15:31:16

标签: c# c#-4.0 search sitecore sitecore6

我构建了一个函数,用于传递我想要搜索的国家/地区字符串以及我想从搜索结果中获取的文章数。

但是当搜索从Sitecore内容项回来时,我不想在标题的开头显示带有星号(*)的项目领域。这是函数名称:

 protected IEnumerable<Item> ShowHomePageNews(int numOfArticles, string stringofCountries)
    {
        List<Item> items = new List<Item>();
        Sitecore.Search.Index indx = SearchManager.GetIndex("my_index_name");
        using (IndexSearchContext searchContext = indx.CreateSearchContext())
        {
            CombinedQuery query = new CombinedQuery();
            QueryBase catQuery = new FieldQuery("countries", stringofCountries); //FieldName, FieldValue.
            SearchHits results = searchContext.Search(catQuery); //Searching the content items by fields.
            SearchResultCollection result = results.FetchResults(0, numOfArticles);
            foreach (SearchResult i in result)
            {
                Lucene.Net.Documents.Field url = i.Document.GetField("_url");
                Sitecore.Data.ItemUri itemUri = new Sitecore.Data.ItemUri(url.StringValue());
                Sitecore.Data.Items.Item item = Sitecore.Context.Database.GetItem(itemUri.ToDataUri());
                items.Add(item);
            }
        }

        return items;
    }

我在我的PageLoad上调用了这个函数:

rptHomePageNews.DataSource = ShowHomePageNews(4,“USA”);

这是我的标记:

<asp:Panel ID="HomePageNews" runat="server">
<asp:Repeater ID="rptHomePageNews" runat="server">
  <ItemTemplate>
    <li>
        <%--<sc:FieldRenderer ID="FieldRenderer1" FieldName="Date" runat="server" Item="<%# Container.DataItem as Sitecore.Data.Items.Item %>" />--%>
        <a href="<%# Sitecore.Links.LinkManager.GetItemUrl(Container.DataItem as Sitecore.Data.Items.Item) %>">
           <sc:FieldRenderer ID="FieldRenderer2" FieldName="Title" runat="server" Item="<%# Container.DataItem as Sitecore.Data.Items.Item %>" />
        </a>
    </li>
  </ItemTemplate>
</asp:Repeater>

我应该在ShowHomePageNews函数中进行哪些更改?

2 个答案:

答案 0 :(得分:1)

如果您乐意使用Linq,可以使用以下内容替换foreach循环:

var db = Sitecore.Context.Database;

items = result
         .Where(r => !r.Title.StartsWith("*"))
         .Select(r => db.GetItem(new Sitecore.Data.ItemUri(r.Url).ToDataUri()))
         .ToList();

答案 1 :(得分:1)

这里的一种方法是使用LINQ查询进行后过滤,如下所示:

string myTitleField = "My Title Field";
List<Item> results = items.Where(x => x.Fields[myTitleField].Value.Contains("*") == false).ToList();

这样效率不高,因为在开始过滤之前需要加载所有项目。如果效率不是问题,那么这至少提供了一种简单的过滤方式。

然而,我的建议是在索引中添加一个字段,并使用可以过滤的值标记记录(例如“TitleContainsAsterisk”)。然后,您可以更改查询以过滤掉该字段中包含“true”或“1”的结果。

编辑(适用于高级数据库抓取工具) 添加动态字段的配置和代码示例。 注意我没有编译或运行它,我是伪代码我现有的代码:

<dynamicFields hint="raw:AddDynamicFields">
    <dynamicField type="MyNameSpace.TitleContainsAsterisk,MyBinary" 
        name="TitleContainsAsterisk" storageType="YES" indexType="TOKENIZED" vectorType="NO" boost="1f" />
</dynamicFields>

/// <summary>
/// Field Configuration (for the indexer) to index the if there is an asterisk in the title
/// </summary>
public class TitleContainsAsterisk: BaseDynamicField {
    public override string ResolveValue(Item item) {
        string myTitleField = "My Title Field";
        bool containsAsterisk = item.Fields[myTitleField].Value.Contains("*");
        return containsAsterisk ? "1" : "0";
    }
}