NHibernate с SQL Server 2008 диалект не поддерживает переменные ограничения - PullRequest
1 голос
/ 12 ноября 2011

Я борюсь со странным поведением здесь ... Выполняя приложение asp.net mvc3 с NHibernate в качестве ORM и MS SQL Server 2008 в качестве БД, я сталкиваюсь с этими исключениями:

System.NotSupportedException: Dialect does not support variable limits.

Код довольно прост, классический запрос разбивки на страницы:

public IList<Agenzia> getAllAgenzie(int maximumRows, int startRowIndex)
    {           
        using (var session = PersistenceManager.Istance.GetSession()) {
            var result = (from agenzia in session.Query<Agenzia>()
                         select agenzia)
                         .Skip(startRowIndex)
                         .Take(maximumRows)
                         .ToList();
            return result;
        }
    }

А вот конфигурация NHibernate

<?xml version="1.0" encoding="utf-8" ?>
<!-- NHibernate Configuration -->
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
  <session-factory name="NHibernate.xlns">
    <property name="dialect">
      NHibernate.Dialect.MsSql2008Dialect
    </property>
    <property name="connection.driver_class">
      NHibernate.Driver.SqlClientDriver
    </property>
    <property name="show_sql">true</property>    
  </session-factory>
</hibernate-configuration>

Есть идеи, что с ним не так?Я не могу поверить, что NHibernate не поддерживает эту простую нумерацию страниц ...

1 Ответ

1 голос
/ 12 ноября 2011

Какую версию NHibernate вы используете? (последняя версия 3.2)

У меня работает без проблем.

Кроме того, это избыточно:

(from agenzia in session.Query<Agenzia>() select agenzia)

Это эквивалентно:

session.Query<Agenzia>()
...