Hibernate進行時
有關Hibenrate及其相關工具的主頁
隨筆 - 0, 文章 - 16, 評論 - 29, 引用 - 0
數據加載中……
Hibernate3.2對sqlserver2005查詢分頁的處理
對Hibernate的查詢分頁,想必大家都比較熟悉了。setFirstResult()和setMaxResults()就可以搞定。但是使用sqlserver的朋友發現了嗎,hibernate發送的分頁語句中總是會有令人心煩的"select top 數字" 這樣的字符串。比如你一頁顯示50條記錄,現在要查詢第100頁的數據,則會出現"select top 50000"這樣的語句,它是先把前5000條數據抓出到內存中,處理后僅返回最后的50條給你,但是其他的4500條不是多余的了嗎?想想還真是憋火。
網上廣為流傳的一篇文章《實現Hibernate分頁查詢原理解讀》(作者robbin)中已經講的很清楚了,如果數據庫自身支持分頁查詢,那么這種數據庫的Dialect中的supportsLimit()方法將返回true,而Hibernate則才會去調用getLimitString()方法以得到分頁的語句,比如對mysql來說是
pagingSelect.append(
"
limit ?, ?
"
);
而對于oracle是:
pagingSelect.append(
"
select * from ( select row_.*, rownum rownum_ from (
"
);
當然,sqlserver也不甘落后,好像非得supportsLimit它才舒服。它的supportsLimit()也是true,同時它的getLimitString()方法為:
public
String getLimitString(String querySelect,
int
offset,
int
limit)
{
if
( offset
>
0
)
{
throw
new
UnsupportedOperationException(
"
sql server has no offset
"
);
}
return
new
StringBuffer( querySelect.length()
+
8
)
.append(querySelect)
.insert( getAfterSelectInsertPoint(querySelect),
"
top
"
+
limit )
.toString();
}
看到那個“top”的來歷了吧。
而實事上,select top進行分頁查詢的效率非常之低,遠不如下面的語句:
rs.absolute(firstRow);
從《實現Hibernate分頁查詢原理解讀》中可以知道,rs.absolute(firstRow);執行的條件是數據庫Dialect不支持分頁查詢,這句話有點繞,其實它的真正意思是“supportsLimit()方法返回的是false”。當supportsLimit()返回false時,Hibernate采用rs.absolute(firstRow);來進行分頁查詢。說到這里,大家心知肚明了吧。其實解決起來比較簡單,你自己定義一個MySqlServer2005Dialect,繼承于原來的org.hibernate.dialect.SQLServerDialect,覆蓋其supportsLimit()方法,如下:
public
boolean
supportsLimit()
{
return
false
;
}
然后在hibernate配置文件中使用你自己的MySqlServer2005Dialect方言即可。
同時要注意的是,在Loader類的1471行有一個方法,它是:
/** */
/**
* Advance the cursor to the first required row of the <tt>ResultSet</tt>
*/
private
void
advance(
final
ResultSet rs,
final
RowSelection selection)
throws
SQLException
{
final
int
firstRow
=
getFirstRow( selection );
if
( firstRow
!=
0
)
{
if
( getFactory().getSettings().isScrollableResultSetsEnabled() )
{
//
we can go straight to the first required row
rs.absolute( firstRow );
}
else
{
//
we need to step through the rows one row at a time (slow)
for
(
int
m
=
0
; m
<
firstRow; m
++
) rs.next();
}
}
}
它和《實現Hibernate分頁查詢原理解讀》中描述的一樣,如果你的jdbc支持scrollable,那就調用rs.absolute(firstRow)定位到第一行,否則的話,就一行一行去移動吧。因此在配置文件中有一項很重要:
<
prop key
=
"
hibernate.jdbc.use_scrollable_resultset
"
>
true
</
prop
>
(注意我用的是spring的配置文件)上述這一行其實可以不寫,因為默認就是true了,但如果你顯示地把它寫上了,一定要設為true,如果為false的話,則記錄集rs會一行一行去移動,還是很費事的。
posted on 2007-08-06 15:15
caixuetao
閱讀(3679)
評論(4)
編輯
收藏
評論
#
re: Hibernate3.2對sqlserver2005查詢分頁的處理
回復
更多評論
這幾天正在看蔡老師的Hibernate那本書啊!覺得寫得很好!
這篇文章我轉載到我blog上拉,不會介意吧!
2007-08-08 20:48 |
咖啡迷
#
re: Hibernate3.2對sqlserver2005查詢分頁的處理
回復
更多評論
我試了下好像不行, 全部都取了
2008-06-26 11:30 |
agua
#
re: Hibernate3.2對sqlserver2005查詢分頁的處理[未登錄]
回復
更多評論
用最少1k~10w的數據量測試,結果說明,通過調用rs.absolute(firstRow)實現分頁,對于性能的提高并沒有幫助。
2010-03-08 17:55 |
C
#
re: Hibernate3.2對sqlserver2005查詢分頁的處理
回復
更多評論
我的也是不起作用?。。。。。。?任何方言配置了 都不起作用!
2011-05-09 09:49 |
劉玉海
新用戶注冊
刷新評論列表
只有注冊用戶
登錄
后才能發表評論。
網站導航:
博客園
IT新聞
Chat2DB
C++博客
博問
管理
Powered by:
BlogJava
Copyright © caixuetao
導航
BlogJava
首頁
新隨筆
聯系
聚合
管理
<
2025年5月
>
日
一
二
三
四
五
六
27
28
29
30
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
1
2
3
4
5
6
7
留言簿
(59)
給我留言
查看公開留言
查看私人留言
隨筆分類
隨筆
(rss)
文章檔案
2007年8月 (1)
2007年4月 (1)
2006年7月 (3)
2006年6月 (1)
2006年3月 (2)
2006年2月 (3)
2006年1月 (1)
2005年10月 (4)
搜索
最新評論
1.?re: HibernateTemplate中HibernateCallback的事務
不錯 看了三個禮拜,終于看懂了!~~深度解析
--和大象掰腕子
2.?re: HibernateTemplate中HibernateCallback的事務[未登錄]
怎樣獲得session?
--aa
3.?re: HibernateTemplate中HibernateCallback的事務[未登錄]
評論內容較長,點擊標題查看
--過客
4.?re: Hibernate3.2對sqlserver2005查詢分頁的處理
我的也是不起作用?。。。。。?! 任何方言配置了 都不起作用!
--劉玉海
5.?re: Hibernate3.2對sqlserver2005查詢分頁的處理[未登錄]
用最少1k~10w的數據量測試,結果說明,通過調用rs.absolute(firstRow)實現分頁,對于性能的提高并沒有幫助。
--C
主站蜘蛛池模板:
国产精品免费综合一区视频
|
免费观看AV片在线播放
|
又粗又硬又黄又爽的免费视频
|
亚洲毛片免费视频
|
免费观看美女用震蛋喷水的视频
|
亚洲国产精品无码中文字
|
黄色网站软件app在线观看免费
|
亚洲人成免费网站
|
亚洲黄色免费网站
|
久久亚洲精品成人AV
|
蜜桃成人无码区免费视频网站
|
亚洲一区精品中文字幕
|
日韩中文字幕免费视频
|
亚洲国产成人九九综合
|
成年女人毛片免费观看97
|
亚洲精品无码av片
|
免费人成网站在线高清
|
一级日本高清视频免费观看
|
免费国产黄网站在线观看视频
|
xxxx日本免费
|
亚洲日韩精品无码AV海量
|
国产成人免费片在线观看
|
一级特黄色毛片免费看
|
国产亚洲免费的视频看
|
日本在线高清免费爱做网站
|
国产亚洲精品bv在线观看
|
免费中文字幕不卡视频
|
在线观看免费视频网站色
|
精品亚洲成a人片在线观看
|
成人婷婷网色偷偷亚洲男人的天堂
|
国产免费131美女视频
|
国产精品偷伦视频免费观看了
|
亚洲第一区香蕉_国产a
|
国产精品美女午夜爽爽爽免费
|
久久久久亚洲精品无码网址色欲
|
亚洲五月六月丁香激情
|
巨胸喷奶水视频www网免费
|
v片免费在线观看
|
亚洲天堂中文字幕
|
免费成人在线观看
|
亚洲黄色片免费看
|