本文目錄一覽:
- 1、MySql中查詢語句實現分頁功能
- 2、怎樣用mysql語句實現分頁
- 3、新手怎麼以最簡單的方式實現jsp+mysql分頁
- 4、MySQL分頁的sql語言怎麼寫?
- 5、MyBatis怎樣實現MySQL動態分頁
MySql中查詢語句實現分頁功能
pageNow代表當前頁面,第一頁。
第一部分:看一下分頁的基本原理:
對上面的mysql語句說明:limit 10000,20的意思掃描滿足條件的10020行,扔掉前面的10000行,返回最後的20行,問題就在這裡,如果是limit 100000,100,需要掃描100100行,在一個高並發的應用里,每次查詢需要掃描超過10W行,性能肯定大打折扣。文中還提到limit n性能是沒問題的,因為只掃描n行。
第二部分:根據雅虎的幾位工程師帶來了一篇Efficient Pagination Using MySQL的報告內容擴展:在文中提到一種clue的做法,給翻頁提供一些線索,比如還是SELECT * FROM message ORDER BY id DESC,按id降序分頁,每頁20條,當前是第10頁,當前頁條目id最大的是1020,最小的是1000,如果我們只提供上一頁、下一頁這樣的跳轉(不提供到第N頁的跳轉),那麼在處理上一頁的時候SQL語句可以是:
處理下一頁的時候SQL語句可以是:
不管翻多少頁,每次查詢只掃描20行。
缺點是只能提供上一頁、下一頁的鏈接形式,但是我們的產品經理非常喜歡「上一頁 1 2 3 4 5 6 7 8 9 下一頁」這樣的鏈接方式,怎麼辦呢?
如果LIMIT m,n不可避免的話,要優化效率,只有儘可能的讓m小一下,我們擴展前面的clue做法,還是SELECT * FROM message ORDER BY id DESC,按id降序分頁,每頁20條,當前是第10頁,當前頁條目id最大的是2519,最小的是2500;
當是第10頁的SQL如下:
比如要跳到第9頁,SQL語句可以這樣寫:
比如要跳到第8頁,SQL語句可以這樣寫:
原理還是一樣,記錄住當前頁id的最大值和最小值,計算跳轉頁面和當前頁相對偏移,由於頁面相近,這個偏移量不會很大,這樣的話m值相對較小,大大減少掃描的行數。其實傳統的limit m,n,相對的偏移一直是第一頁,這樣的話越翻到後面,效率越差,而上面給出的方法就沒有這樣的問題。
怎樣用mysql語句實現分頁
–1.最常用的分頁select * from content order by id desc limit 0, 10;–limit是MySQL中特有的分頁語法,用法如下:–舉例:select * from tableName limit 5; –返回前5行select * from tableName limit 0,5; –同上,返回前5行select * from tableName limit 5,10; –返回6-15行
新手怎麼以最簡單的方式實現jsp+mysql分頁
剛開始弄 ,目前分頁是在前台jsp中實現的 與bean相比 這樣比較容易一些
先把代碼貼出來 正在研究怎麼樣用bean實現分頁 等弄好了 再貼代碼
下面說下分頁理論 select * from message order by time desc limit begin,size
begin 數據記錄從第幾條開始 begin=(當前頁數-1)*size
size 每頁的記錄數
下面是連接數據庫的javabean;
1: package bean;
2: import java.sql.*;
3:
4: public class MyDb{
5: private Statement stmt;
6: private Connection conn=null;
7: private ResultSet rs=null;
8:
9: public void connection(String db_name,String user,String pwd) throws Exception{
10: Class.forName(“com.mysql.jdbc.Driver”);
11: String url=”jdbc:mysql://localhost:3306/” + db_name;
12: conn=DriverManager.getConnection(url,user,pwd);
13: stmt=conn.createStatement();
14: }
15:
16: public ResultSet query(String sql) throws Exception{
17: rs=stmt.executeQuery(sql);
18: return rs;
19: }
20:
21: public ResultSet query(String sql,int begin,int size) throws Exception{
22: String s=” limit ” + begin + “,” +size;
23: sql=sql + s;
24: rs=stmt.executeQuery(sql);
25: return rs;
26: }
27:
28:
29: public int update(String sql) throws Exception{
30: int n=0;
31: n=stmt.executeUpdate(sql);
32: return n;
33: }
34:
35: public boolean delete(String sql) throws Exception{
36: 0ff”boolean flag=false;
37: flag=stmt.execute(sql);
38: return flag;
39: }
40: }
下面是jsp的代碼;
1: jsp:useBean id=”db” class=”bean.MyDb” scope=”page” /
2: %
3: int page_count; //總頁數
4: int p; //當前面號
5: int size=3; //每頁記錄數
6: int result_count; //總記錄數
7: int begin; //當前頁第一條記錄索引號
8: ResultSet rs=null;
9: String page_s=request.getParameter(“page”);
10: if(page_s==null) page_s=”1″;
11: db.connection(“test”,”root”,”root”);
12: String sql=”select count(*) from message”;
13: rs=db.query(sql);
14: rs.next();
15: result_count=rs.getInt(1);
16: page_count=(result_count + size – 1)/size;
17: p=Integer.parseInt(page_s);
18: out.println(“總記錄數為:” + result_count + ” 每頁記錄數為:” + size + ” 總頁數為:” + page_count + ” 當前是第” + p + “頁”);
19: sql=”select * from message order by time desc”;
20: begin=(p-1)*size;
21: rs=db.query(sql,begin,size);
22: while(rs.next()){
23: %
24: table
25: tr
26: td width=”200″%=rs.getString(1)%/td
27: td width=”200″%=rs.getString(2)%/td
28: /tr
29: tr
30: td%=rs.getString(3)%/td
31: td%=rs.getString(4)%/td
32: /tr
33: trtd colspan=”2″%=rs.getString(5)%/td/tr
34: trtd colspan=”2″hr //td/tr
35: /table
36: %
37: }
38: if(p1) out.println(“a href=test.jsp?page=” + (p-1) + “上一頁/a”);
39: if(ppage_count) out.println(“a href=test.jsp?page=” + (p+1) + “下一頁/a”);
40: %
MySQL分頁的sql語言怎麼寫?
1、首先我們建立一個表表的數據,這個表裡有25條數據,id從1到25。(下圖是部分截圖)
2、要分頁數據,首先我們假設一頁有10條數據,我們可以用mysql的 limit關鍵字來限定返回多少條數據。並且用order by來排序數據,這裡用 id來排序。所以第一頁的sql可以如圖這樣寫。
3、執行後得到的數據如圖,就是 id從1到10的前10條數據,因為我們是按id升序來排序的。
4、上面第一頁的sql是簡化的寫法,完整的寫法如圖,得到的結果和上圖的一模一樣。代碼里 limit 0, 10 的意思是從第一條數據開始,取10條數據。(注意的是第一條數據是從0開始的)
5、那麼第二頁的數據,關鍵是要知道是從哪一條數據開始,可以用這個公式得到: (頁碼-1) * 每頁顯示多少條,即 (2-1) * 10 = 10, 所以sql語句如圖, limit 10, 10。
6、執行後,結果正確,得到id從11到20的10條數據。
7、同理第三頁數據的sql如圖,br/就是 limit 20, 10。
8、查詢的結果如圖,因為這頁只剩下5條數據了,所以只顯示5條數據。如果你有更多頁的數據,後面的數據只需要按上面的公式,得到從哪行開始,就可以寫對應的sql語句了。
MyBatis怎樣實現MySQL動態分頁
一、mysql使用limit子句來實現數據庫的物理分頁,limit子句接受一個或兩個參數,第一個參數指定第一個返回記錄行的偏移量,第二個參數指定返回記錄行的最大數量。在mybatis中,只需要在相應的查詢語句後,加上limit子句,即可實現物理分頁。如下,以一個只有字段id,name,age的表為例。該配置會根據傳入的hashmap,如果含有鍵start和鍵end,那麼即通過mybatis強大的動態sql,生成含有mysql分頁的sql語句。select*fromuserslimit#{start},#{end}二、mybaits簡介mybatis,前稱ibatis,後改名為mybatis,截止本文成文,最新版本是3.0.6。它和hibernate是java世界使用最多的兩種orm框架。hibernate理念最為先進,完全實現面向對象的數據庫編程,不需要掌握sql語句,即可實現數據庫操作,能夠節省開發人員編寫大量sql語句的時間。但是,hibernate在處理多表關聯時,可能會出現n+1問題,性能會有較大影響,要解決性能問題,需要較深的hibernate知識和項目經驗。mybatis需要自己寫sql語句,開發效率不如hibernate,很難做到底層多數據庫的通用。但對程序員來說有更高的可控性,可以更容易的對sql語句進行優化,提高效率。在開發中直接使用jdbc一個非常普遍的問題就是動態sql。如果參數值、參數本身和數據列都是動態sql,通常的解決方法就是寫很多if-else條件語句和字符串連接。而mybatis通過ognl提供了一套非常清晰的方法來解決動態sql的問題。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/244157.html