注册本站  论坛  繁體中文

电脑技巧
手机 | MP3 | MP4 | 显卡 | 主板 | 显示器 | 光存储 | 笔记本 | 网络设备 | 移动存储 | 数码相机
键鼠 | CPU | 音箱 | GPS | 电视 | 服务器 | 投影机 | 机箱电源 | 品牌电脑 | 办公打印 |
| 网站首页 | Cisco | Windows | Linux | Java | Dotnet | Oracle | 网页设计 | 平面设计 | 安全 | 软件应用 | 电脑维修 | 办公维修 |
您现在的位置: 电脑技巧 >> Java >> 开源技术 >> Hibernate >> Java正文

hibernate在sql server下分页的处理

文章来源:中国IT实验室收集整理 作者:佚名 更新时间:2008-6-28 20:35:35 【 】 【加入收藏
  今天要在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条全部查出来吗?但是我测试的结果就是如果我要去第5000页的数据,他就是select top 10000 * from ……这样取出来的。但是如果把sql dialect  改成oracle,处理是用  rownum    直接去取需要的中间那么多条记录的。明天升级到最新的hibernate 3.3试试看会不会这样。难道java的开源框架对sql server这么感冒? 呵呵
 
  监控了下数据库,发现公司的php程序在翻页时也是这样处理的,我就奇怪了,sql server2005中也有rownum概念的啊。看来代码从sql server2000到2005以后还是要做一些优化的
  • 上一篇Java:

  • 下一篇Java:
  • 最 新 热 门
     手机开发平台指南、教程和资料介绍
     关于什么叫面向接口编程
     编写高级JavaScript应用代码
     不要验证,直接转化科学计数法
     Eclipse插件开发中实现刷新和重编译介绍
     Java开源技术:Eclipse的使用技巧详解
     配置eclipse 3.2 使用JDK1.5中文JavaAPI
     集成Windows本地应用到Eclipse RCP 程序中
     hibernate.cfg.xml配置文件的说明
     eclipse开发jface时,main.class解决方法
    最 新 推 荐
     从Hibernate的映射谈编程思想
     JSF和Hibernate的比较
     hibernate的核心接口
     利用ThreadLocal绑定Hibernate的session
     Struts2 Spring Hibernate 的简单整合
     在Hibernate中创建安全Session
     hibernate在sql server下分页的处理
     hibernate3二级缓存的配置及测试
     Hibernate一对多双向映射及乐观锁使用
     Java开发中关于Hibernate对多表关联查询
    相 关 文 章

    hibernate.cfg.xml配置文件的说明
    ibatis+spring 集成
    Spring+Ibatis+事务处理
    从Hibernate的映射谈编程思想
    JSF和Hibernate的比较
    hibernate的核心接口
    利用ThreadLocal绑定Hibernate的session
    Struts2 Spring Hibernate 的简单整合
    在Hibernate中创建安全Session
    hibernate3二级缓存的配置及测试

    | 设为首页 | 加入收藏 | 联系站长 | 友情链接 | 版权申明 | 网站公告

     

    Copyright 2006-2008 pcjx.com All Rights Reserved
    电脑技巧 版权所有 粤ICP备06059145号 地图
    本网站所有内容未经许可不得转载或做其他使用