NHibernate与sql Server 2008方言不支持变量限制

时间:2011-11-12 17:37:00

标签: sql-server-2008 nhibernate linq-to-nhibernate

我在这里与一种奇怪的行为作斗争...... 使用NHibernate作为ORM和MS SQL Server 2008作为数据库执行asp.net mvc3应用程序,我遇到了这些例外:

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 个答案:

答案 0 :(得分:1)

您使用的是什么版本的NHibernate? (最新的是3.2)

对我来说没有问题。

此外,这也是多余的:

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

相当于:

session.Query<Agenzia>()