首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >NHibernate.Search - SQL Server2005-达到最大参数限制2100!

NHibernate.Search - SQL Server2005-达到最大参数限制2100!
EN

Stack Overflow用户
提问于 2011-05-05 11:43:42
回答 1查看 833关注 0票数 0

我在我的项目中使用NHibernate.Search库进行自由文本搜索。最近,当我开始获得超过2100个结果时,我开始从SQL Server获得最大参数长度错误。

NHibernate.Search会处理这种情况吗?有没有什么变通办法?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-05-05 23:11:59

您可以修改NHibernate.Search代码来处理这一点,或者使用自定义分页,IE获取搜索的命中数,然后相应地分页nhibernate搜索结果。

代码语言:javascript
复制
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;
}

请参阅:IFullTextQuery - exception if there are too may objects

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5892433

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档