Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/sql-server-2005/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql server 2005 搜索-SQLServer2005-达到最大参数限制2100!_Sql Server 2005_Nhibernate.search - Fatal编程技术网

Sql server 2005 搜索-SQLServer2005-达到最大参数限制2100!

Sql server 2005 搜索-SQLServer2005-达到最大参数限制2100!,sql-server-2005,nhibernate.search,Sql Server 2005,Nhibernate.search,我在项目中使用NHibernate.Search库进行免费文本搜索。最近,当我开始获得2100多个结果时,我开始从SQL Server获得最大参数长度错误 NHibernate.Search会处理这种情况吗?任何人有任何解决方法吗?您可以修改NHibernate.Search代码来解决这个问题,或者使用自定义分页,即获取搜索的点击数,然后相应地分页NHibernate搜索结果 public IList<TEntity> Search<TEntity>(Query quer

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


NHibernate.Search会处理这种情况吗?任何人有任何解决方法吗?

您可以修改NHibernate.Search代码来解决这个问题,或者使用自定义分页,即获取搜索的点击数,然后相应地分页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;
}
公共IList搜索(查询查询、bool?活动、字符串orderBy)
{
var search=NHibernate.search.search.CreateFullTextSession(this.session);
var total=search.CreateFullTextQuery(query,typeof(tenty)).ResultSize;
var first=0;
var l=新列表();
而(总数>0)
{
l、 AddRange(search.CreateFullTextQuery(查询,类型(tenty))
.SetFirstResult(第一个)
.SetMaxResults(1000)
.List());
第一+=1000;
总数-=1000;
}
返回l;
}
见: