我正在使用SolrNet在一组表上搜索数据。如何在SolrNet的多个表上执行索引/搜索
我有两个表分类和项目。
这两个表具有相同的字段,因此我有一个基础映射类形式,我导出。索引分类数据
[Serializable]
[XmlRoot(ElementName = "SolrSearchEntity", Namespace = "")]
[DataContract(Name = "SolrSearchEntity", Namespace = "")]
public class SolrSearchEntity
{
[XmlElement(ElementName = "Id")]
[DataMember(Name = "Id", IsRequired = true)]
[SolrUniqueKey("id")]
public string Id { get; set; }
[XmlElement(ElementName = "Name")]
[DataMember(Name = "Name", IsRequired = true)]
[SolrField("name")]
public string Name { get; set; }
}
public class Category : SolrSearchEntity
{
}
public class Item : SolrSearchEntity
{
}
代码块
using (SolrBaseRepository.Instance<Category> repository = new SolrBaseRepository.Instance<Category>())
{
var output = ItemStoreDataManager.GetAllCategoryNames(dataAdapter);
repository.Start();
var solr = ServiceLocator.Current.GetInstance<ISolrOperations<Category>>();
solr.AddRange(output);
solr.Commit();
}
索引项数据代码块
using (SolrBaseRepository.Instance<Item> repository = new SolrBaseRepository.Instance<Item>())
{
var output = ItemStoreDataManager.GetAllItemNames(dataAdapter);
repository.Start();
var solr = ServiceLocator.Current.GetInstance<ISolrOperations<Item>>();
solr.AddRange(output);
solr.Commit();
}
我Schema.xml的具有
<fields>
<!-- declare fields of entity class -->
<field name="id" type="string" indexed="true" stored="true" required="true" multiValued="false" />
<field name="name" type="text_general" indexed="true" stored="true" omitNorms="true"/>
<field name="text" type="text_general" indexed="true" stored="false" multiValued="true"/>
<field name="_version_" type="long" indexed="true" stored="true"/>
</fields>
查询的类别数据
var entities = ItemStoreManager<Category>.Search(keyword); which will internally execute this.
new SolrBaseRepository.Instance<T>().Start();
var solr = ServiceLocator.Current.GetInstance<ISolrOperations<T>>();
var results = solr.Query(keyword);
奇怪的是,我从项目表中获取的记录。
我该如何告诉SolrNet(搜索引擎)来查看我指定的类型。
或者我在第一个地方正确编制索引?
请帮忙。
感谢,
谢谢厨师。我采取了你所建议的方法。但是,表格的id值与正在运行的数字相似(重叠)。因此,我收到不正确的数据,查询类别退货项目数据。如何处理这个? – Prasad
谢谢厨师。我采取了你所建议的方法。但是,表格的id值与正在运行的数字相似(重叠)。因此,我收到不正确的数据,查询类别退货项目数据。如何处理这个? – Prasad