本篇內(nèi)容主要講解“Hibernate分頁管理怎么實現(xiàn)”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“Hibernate分頁管理怎么實現(xiàn)”吧!
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:申請域名、虛擬主機、營銷軟件、網(wǎng)站建設(shè)、衡陽縣網(wǎng)站維護、網(wǎng)站推廣。
Hibernate中,通過對不同數(shù)據(jù)庫的統(tǒng)一接口設(shè)計,實現(xiàn)了透明化、通用化的分頁實現(xiàn)機制。
通過Criteria.setFirstResult和Criteria.setFetchSize方法設(shè)定分頁范圍,如:
Criteria criteria = session.createCriteria(TUser.class); criteria.add(Expression.eq("age", "20")); //從檢索結(jié)果中獲取第100條記錄開始的20條記錄 criteria.setFirstResult(100); criteria.setFetchSize(20);
通過Query.setFirstResult和Query.setMaxResults方法也可以設(shè)定分頁范圍,如:
Query query = session.createQuery("from TUser"); query.setFirstResult(100); query.setMaxResults(20); // query.setFetchSize(20); List list = query.list();
Hibernate中,抽象類org.hibernate.dialect.Dialect指定了所有底層數(shù)據(jù)庫的對外統(tǒng)一接口,通過針對不同數(shù)據(jù)庫提供相應(yīng)的Dialect實現(xiàn),數(shù)據(jù)庫之間的差異性得以消除,從而為上層機制提供了透明的、數(shù)據(jù)庫無關(guān)的存儲層基礎(chǔ)。對于分頁機制而言,Dialect中定義了一個方法如下:
/** * Add a LIMIT clause to the given SQL SELECT * * @return the modified SQL */ public String getLimitString(String querySelect, boolean hasOffset) { throw new UnsupportedOperationException( "paged queries not supported" ); } public String getLimitString(String querySelect, int offset, int limit) { return getLimitString( querySelect, offset>0 ); }
此方法用于在現(xiàn)有Select語句基礎(chǔ)上,根據(jù)各個數(shù)據(jù)庫自身特性,構(gòu)造對應(yīng)的記錄返回限定子句。如MySQL中對應(yīng)的記錄限定子句為Limit,Oracle中,通過rownum子句實現(xiàn)。MySQLDialect中的getLimitString實現(xiàn):
public String getLimitString(String sql, boolean hasOffset) { return new StringBuffer( sql.length()+20 ) .append(sql) .append( hasOffset ? " limit ?, ?" : " limit ?") .toString(); }
MySQLDialect.getLimitString方法的實現(xiàn)實際上是在給定的Select語句后追加MySQL所提供的專有SQL子句limit來實現(xiàn)。
Oracle9Dialect中的getLimitString實現(xiàn):
public String getLimitString(String sql, boolean hasOffset) { sqlsql = sql.trim(); boolean isForUpdate = false; if ( sql.toLowerCase().endsWith(" for update") ) { sqlsql = sql.substring( 0, sql.length()-11 ); isForUpdate = true; } StringBuffer pagingSelect = new StringBuffer( sql.length()+100 ); if (hasOffset) { pagingSelect.append("select * from ( select row_.*, rownum rownum_ from ( "); } else { pagingSelect.append("select * from ( "); } pagingSelect.append(sql); if (hasOffset) { pagingSelect.append(" ) row_ where rownum <= ?) where rownum_ > ?"); } else { pagingSelect.append(" ) where rownum <= ?"); } if ( isForUpdate ) { pagingSelect.append( " for update" ); } return pagingSelect.toString(); }
通過Oracle特有的rownum子句來實現(xiàn)數(shù)據(jù)部分的讀取。SQLServerDialect中的getLimitString實現(xiàn):
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(); }
通過SQLServer特有的top子句實現(xiàn)。HSQLDialect中的getLimitString實現(xiàn):
public String getLimitString(String sql, boolean hasOffset) { return new StringBuffer( sql.length() + 10 ) .append( sql ) .insert( sql.toLowerCase().indexOf( "select" ) + 6, hasOffset ? " limit ? ?" : " top ?" ) .toString(); }
大多數(shù)主流數(shù)據(jù)庫都提供了數(shù)據(jù)部分讀取機制,而對于某些沒有提供相應(yīng)機制的數(shù)據(jù)庫而言,Hibernate也通過其他途徑實現(xiàn)了分頁,如通過Scrollable ResultSet,如果JDBC不支持Scrollable ResultSet,Hibernate也會通過ResultSet的next方法進(jìn)行記錄定位。Hibernate通過底層對分頁機制的良好封裝,使得開發(fā)人員無需關(guān)心數(shù)據(jù)分頁的細(xì)節(jié)實現(xiàn),將數(shù)據(jù)邏輯和存儲邏輯分離開來,在提高生產(chǎn)效率的同時,也大大加強了系統(tǒng)在不同數(shù)據(jù)庫平臺之間的可移植性。
到此,相信大家對“Hibernate分頁管理怎么實現(xiàn)”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!