Solr.NET快速入门(七)【覆盖默认映射器,NHibernate集成】

覆盖默认映射器

默认情况下,SolrNet使用属性映射Solr字段。 但是,您可能需要使用另一个映射程序。 替换默认映射器取决于您如何设置库:
内置容器

如果使用默认的内置容器,可以在调用Startup.Init()之前替换它:

var mapper = new MappingManager();
//这里是你的映射
var container = new Container(Startup.Container);
container.RemoveAll<IReadOnlyMappingManager>();
container.Register<IReadOnlyMappingManager>(c => mapper);
ServiceLocator.SetLocatorProvider(() => container);
Startup.Init<Document>("http://localhost:8983/solr");

Windsor设施

如果您使用Windsor设施,您可以覆盖映射器,如下所示:

var mapper = new MappingManager();
/* Here come your mappings */
var solrFacility = new SolrNetFacility("http://localhost:8983/solr") {Mapper = mapper};
var container = new WindsorContainer();
container.AddFacility("solr", solrFacility);

Ninject模块

var mapper = new MappingManager();
/*这里是你的映射* /
var c = new StandardKernel();
c.Load(new SolrNetModule("http://localhost:8983/solr") {Mapper = mapper});

NHibernate-SolrNet集成

SolrNet中包含了NHibernate-SolrNet模块,具有以下功能:

 自动数据库 - > Solr同步
 从NHibernate的ISession发出Solr查询

这旨在用于在NHibernate和SolrNet上类似映射的实体。

此集成已弃用。 它不是通用的,不能真正可重用于大多数非平凡的情况。 它将在未来的SolrNet版本中删除。

建立

照常配置SolrNet和NHibernate。 然后应用SolrNet的集成到NHibernate的配置像这样:

NHibernate.Cfg.Configuration cfg = SetupNHibernate();
var cfgHelper = new NHibernate.SolrNet.CfgHelper();
cfgHelper.Configure(cfg, true); // true - >在每次操作后自动提交Solr(不推荐)

如果您不使用默认的内置容器,您必须告诉CfgHelper使用它,例如:

IWindsorContainer container = new WindsorContainer();
...
var cfgHelper = new NHibernate.SolrNet.CfgHelper(container);
...

用法

每当创建,更新或删除也在SolrNet中映射的NHibernate实体时,它将在Solr上自动更新。 NHibernate事务被授予:只有当NHibernate事务被提交时,实体才在Solr上被更新。

这种同步仅在NHibernate - > SolrNet的方向上进行,而不是相反,即直接通过ISolrOperations发出的操作不会反映在NHibernate上。

为了通过NHibernate发出Solr查询,ISession需要包装。 示例:

ISessionFactory sessionFactory = ...
using (var session = cfgHelper.OpenSession(sessionFactory)) {
   ICollection<Entity> entities = session.CreateSolrQuery("this is a full-text query").SetMaxResults(10).List<Entity>();
}
原文地址:https://www.cnblogs.com/Wulex/p/6962058.html