我正在将 web 项目 asp.net VS2008 迁移到 VS2010,并将 NH 2.1 迁移到 NH 3.2。
现在,使用 NH 3.2 的分页不起作用。
NHibernate 3.2 SetFirstresult, Setmaxresults 分页问题 oracle
https://groups.google.com/forum/#!topic/nhusers/1kp0hDfVol0
代码,vs2008和vs2010相同,但是使用NH 3.2,分页不起作用
var response = new GetComunicacionesXFiltroResponse();
//Sesion
using (ISession session = NHibernateHelper.OpenSession(FlushMode.Never))
{
IQuery query = GetQueryForGetComunicacionesXFiltro(request, false, session);
if (request.PagingInfo != null)
{
query.SetMaxResults(request.PagingInfo.RowCount);
query.SetFirstResult((request.PagingInfo.PageNumber - 1) * request.PagingInfo.RowCount);
}
response.Comunicaciones = ComunicacionMapper.Map(query.List<Comunicacion>());
}
NH 3.2 的配置
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2" >
<reflection-optimizer use="false"/>
<session-factory>
<property name="connection.connection_string_name">XXX.ConnectionStrings.Oracle.XXX</property>
<property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property>
<property name="connection.driver_class">NHibernate.Driver.OracleDataClientDriver</property>
<property name="connection.isolation">ReadCommitted</property>
<property name="dialect">NHibernate.Dialect.Oracle9iDialect</property>
<property name="query.substitutions">true 1, false 0, yes 'Y', no 'N'</property>
<property name="show_sql">false</property>
<property name="use_proxy_validator">false</property>
<!--DEPRECATED<property name="use_outer_join">true</property>-->
<mapping assembly="XXX.MonitorizacionB2b.DomainModel"/>
</session-factory>
</hibernate-configuration>
有什么建议吗?