我这里有一个奇怪的行为…做一个asp.net mvc3应用程序与NHibernate作为ORM和MS SQL Server 2008作为DB,我遇到了这些异常:
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竟然不支持这种简单的分页…
你使用的是什么版本的NHibernate ?(最新版本3.2)
对我来说没有问题。
同样,这是多余的:
(from agenzia in session.Query<Agenzia>() select agenzia)
相当于:
session.Query<Agenzia>()