我在我的项目中使用 NHibernate.Search 库进行自由文本搜索。最近,当我开始获得超过 2100 个结果时,我开始从 SQL Server 获得最大参数长度错误。
NHibernate.Search 会处理这种情况吗?任何解决方法吗?
我在我的项目中使用 NHibernate.Search 库进行自由文本搜索。最近,当我开始获得超过 2100 个结果时,我开始从 SQL Server 获得最大参数长度错误。
NHibernate.Search 会处理这种情况吗?任何解决方法吗?
您可以修改 NHibernate.Search 代码来处理这个问题,或者,使用自定义分页,IE 获取您的搜索的点击数,然后相应地分页 nhibernate 搜索结果。
public IList<TEntity> Search<TEntity>(Query query, bool? active, string orderBy)
{
var search = NHibernate.Search.Search.CreateFullTextSession(this.session);
var total = search.CreateFullTextQuery(query, typeof(TEntity)).ResultSize;
var first = 0;
var l = new List<TEntity>();
while (total > 0)
{
l.AddRange(search.CreateFullTextQuery(query, typeof(TEntity))
.SetFirstResult(first)
.SetMaxResults(1000)
.List<TEntity>());
first += 1000;
total -= 1000;
}
return l;
}