java web oracle 分页_Java Web中将oracle的数据库内容以表格形式展现到页面中(分页展示)...

分页SQL语句:

----分页显示

select * from (select rownum as r,t.* from(select emp.* from emp order by hiredate desc) t where rownum<=10)where r>5;

查询的结果如下:

93f8b2e267c1636afe05d19d37dc32ec.png

这个SQL,使用了三层嵌套的查询方式:

1)最内层的select 语句

最内层的Select语句是一条普通的查询语句,它的执行结果,将是emp表中的所有数据按照受雇日期降序排列.

2)第二层的select 语句

这一层的Select 语句使用了rownum,这条语句的执行结果就是从最内层语句的查询结果中按照rownum的顺序取出前10条.实际上,中间层的select 语句的执行结果是限制查询记录数量的最大记录数。

3)最外层的select 语句

既然中间层的select语句控制了查询过程中数据的最大记录数,那么最外层的select语句就要控制查询过程中的最小记录数。由此可以得出的结论是:上面SQL的执行结果就是查询emp表中第6条~~~第10条的数据记录.

通过以上的分析,我们了解了在Oracle众分页查询的实现原理。现在要做的就是在第二层和最外层将数据库记录的最大值和最小值替换成我们需要的值。

String sql="select * from (select rownum as r,t.* from " +"(select emp.* from emp order by hiredate desc) t where rownum<="+(pageSize*pageIndex)+") where r>"+pageSize*(pageIndex-1);

上面就是下面将要使用的分页查询的SQL语句,并使用到了两个变量,分别是pageSize和pageIndex,其中pageSize表示每页显示的数据条数,而pageIndex变量表示当前页的页码。

下面的代码是简单的实现了Oracle分页查询在JSP分页展示数据的实现。写的比较简单,在JSP中嵌套java代码比较乱,建议使用Servlet。

首先,需要编写一个是实现分页查询的java类,没有进行特殊的整合,凑合着吧,原理就是这样:

在分页显示时,每页显示数据量是固定的,假设每页显示10条数据,第1页的编号就是1到10,当用户单击第二页时显示的数据编号为11--20,以此类推,限制最后一页。

这样我们可以总结出一个规律:

每页显示的第一条数据行号应该等于 【每页显示的数据量*(当前页码-1)+1】。-----可以看出上面的SQL的最外层 R>【每页显示的数据量*(当前页码-1)】,这样行号才匹配。

每页显示的最后一条数据行号等于【每页显示的数据量*当前页码】。

经过分析,我们对上面的SQL进行修改,得到下面的代码:

1 packagecom.dao;2

3 importjava.sql.Connection;4 importjava.sql.DriverManager;5 importjava.sql.PreparedStatement;6 importjava.sql.ResultSet;7 importjava.sql.SQLException;8 importjava.util.ArrayList;9 importjava.util.HashMap;10 importjava.util.List;11 importjava.util.Map;12

13 public classEmpDao {14 private Connection conn=null;15 private PreparedStatement psmt=null;16 private ResultSet rs=null;17 /**

18 * 获得数据库连接19 */

20 private voidopenConn(){21 //首先定义下连接数据的URL、用户名、密码

22 String url="jdbc:oracle:thin:@127.0.0.1:1521:orcl";23 String user="scott";24 String password="yulei123";25 try{26 Class.forName("oracle.jdbc.driver.OracleDriver");27 conn=DriverManager.getConnection(url,user,password);28 } catch(ClassNotFoundException e) {29 e.printStackTrace();30 } catch(SQLException e) {31 e.printStackTrace();32 }33 }34 /**

35 * 获得所有员工数据36 */

37 publicList getAllemp(){38 List list=newArrayList();39 openConn();40 String sql="select * from emp order by hiredate desc";41 try{42 psmt=conn.prepareStatement(sql);43 rs=psmt.executeQuery();44 while(rs.next()){45 Map emps=newHashMap();46 emps.put("empno", rs.getString("empno"));47 emps.put("ename",rs.getString("ename"));48 emps.put("sal", rs.getString("sal"));49 list.add(emps);50 }51 } catch(SQLException e) {52 e.printStackTrace();53 }54 returnlist;55 }56 /**

57 * 获取第几页的数据58 */

59 public List getAllempByPage(int pageSize,intpageIndex){60 List list =newArrayList();61 String sql="select * from (select rownum as r,t.* from " +

62 "(select emp.* from emp order by hiredate desc) t where rownum<="+(pageSize*pageIndex)63 +") where r>"+pageSize*(pageIndex-1);64 try{65 psmt=conn.prepareStatement(sql);66 rs=psmt.executeQuery();67 while(rs.next()){68 Map map=newHashMap();69 map.put("empno", rs.getString("empno"));70 map.put("ename",rs.getString("ename"));71 map.put("sal", rs.getString("sal"));72 list.add(map);73 }74 } catch(SQLException e) {75 e.printStackTrace();76 }77 returnlist;78 }79 /**

80 * 获取员工的总数81 *82 */

83 public intcountEmp(){84 int count=0;85 String sql="select count(*) from emp";86 openConn();87 try{88 psmt=conn.prepareStatement(sql);89 rs=psmt.executeQuery();90 while(rs.next()){91 count=rs.getInt(1);92 }93 } catch(SQLException e) {94 e.printStackTrace();95 }96 returncount;97 }98 /**

99 * 根据每页显示的数量,得到总页数100 */

101 public int getTotalPage(intpageSize){102 int totalPage=countEmp();103 return (totalPage%pageSize==0)?(totalPage/pageSize):(totalPage/pageSize+1);104 }105 }

接下来就是编写JSP文件,命名为pageTest.jsp.

1

2

3

4

5

6

7

Oracle分页

8

9

10

11 EmpDao ed=newEmpDao();12 intpageSize=4;//每页显示的记录13 inttotalpages=ed.getTotalPage(pageSize);//最大页数14 StringcurrentPage=request.getParameter("pageIndex");//获得当前的页数,即第几页15 if(currentPage==null){16 currentPage="1";17 }18 intpageIndex=Integer.parseInt(currentPage);19 //添加逻辑判断,防止页数异常20 if(pageIndex<1){21 pageIndex=1;22 }else if(pageIndex>totalpages){23 pageIndex=totalpages;24 }25 List list=ed.getAllempByPage(pageSize,pageIndex);//返回特定页数的数据26 %>

27

28

29

30

员工工号

31

员工姓名

32

员工工资

33

34

35 Map map=null;36 for(inti=0;i

39

40

41

42

43

44

45

46 首页

47 ">上一页

48 ">下一页

49 ">末页

50

51 当前页数:

52

53

最后,我们在浏览器访问这个JSP文件.

本文来源于:

http://blog.csdn.net/yulei_qq/article/details/16829695

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值