讲解Hibernate query语句

Hibernate还是比较常用的,于是我研究了一下Hibernate query语句,在这里拿出来和大家分享一下,希望对大家有用。

今天要在sqlserver环境下做一个简单的增删改功能,要用到分页,开始直接用oracle数据库环境一直用的一个jdbc重构过的类处理,发现不行,才想起oracle和sqlserver的分页sql语句写法是很不一样的,于是打算google一下,紧接又想,何不先看看Hibernate在sqlserver环境是怎么处理分页的(我这里用的是Hibernate 3.0)。

先把Hibernate配置文件的show_sql改成true,启动tomcat,在项目原来的一个功能里找到一个翻页的地方,比如每页显示两条,第一页的时候,Hibernate query语句是:SELECT TOP 2 * FROM  …… 恩,对的,看来Hibernate还比较聪明,第一页直接用top语句,可是点下一页,当查询的记录应是3-4条时,Hibernate query语句是: SELECT TOP 4 * FROM…… 不理解了,难道Hibernate这么笨吗,如果我要查的是第100万条到100万零10条的记录,难道他也是先把这100万零10条全部查出来吗?

相关推荐