NHibernate.Search - SQL Server 2005 - максимальный предел параметра 2100! - PullRequest
0 голосов
/ 05 мая 2011

Я использую библиотеки NHibernate.Search в своем проекте для свободного текстового поиска. Недавно, когда я начал получать более 2100 результатов, я начал получать ошибку максимальной длины параметра от SQL Server.

NHibernate.Search позаботится о такой ситуации? Любой обходной путь кто-нибудь?

1 Ответ

0 голосов
/ 05 мая 2011

Вы можете изменить код 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;
}

См .: IFullTextQuery - исключение, если есть слишком много объектов

...