Oracle分页存储过程在ibatis中如何调用

数据库 Oracle
以下的文章主要是对ibatis调用Oracle分页存储的实际操作过程,以及其中涉及到Oracle分页的实际操,以下就是文章的具体内容介绍。

你是否对ibatis调用Oracle分页存储过程的实际操作感到十分头疼?如果是这样子的话,以下的文章将会给你相应的解决方案,以下的文章主要是介绍ibatis调用Oracle分页存储过程的操作方案,以下就是相关内容的具体描述。

Oracle 分页:

 

  1. create or replace procedure P_QuerySplit( 

sqlscript varchar2, 表名/SQL语句

pageSize integer, 每页记录数

pageIndex integer, 当前页

totalCount out number, 总记录数

totalPage out number, 总页数

v_cur out sys_refcursor 返回游标

 

  1. ) is  
  2. /**  
  3. * by chenjianxin 2008-5-3  
  4. *  
  5. */  
  6. v_PageSize number;  
  7. v_PageIndex number;  
  8. v_SQL_Count varchar2(4000);  
  9. v_SQL varchar2(4000);  
  10. v_StartIndex number;  
  11. v_EndIndex number;  
  12. begin  
  13. v_PageSize:=pageSize;  
  14. if v_PageSize=0 then  
  15. v_PageSize:=1;  
  16. end if;  

 

统计记录数量

 

  1. v_SQL_Count :'select count(*) from (' ? ? sqlscript ? ?') a ';  
  2. execute immediate v_SQL_Count into totalCount;  

 

计算总页数

 

  1. totalPage:=CEIL(totalCount/v_PageSize); 

验证页号 如果页号大余了***页数,返回***一页

 

  1. v_PageIndex:=pageIndex;  
  2. if v_PageIndex>totalPage then  
  3. v_PageIndex:=totalPage;  
  4. end if;  

 

计算开始的Index和结束的Index

 

  1. v_StartIndex:=(v_PageIndex-1)*v_PageSize 1;  
  2. v_EndIndex:=v_PageIndex*v_PageSize;  
  3. v_SQL:='SELECT /* FIRST_ROWS */* FROM (';  
  4. v_SQLv_SQL:=v_SQL ? ?' SELECT A.*, ROWNUM RN ';  
  5. v_SQLv_SQL:=v_SQL ? ?' FROM (' ? ?sqlscript ? ?') A ';  
  6. v_SQLv_SQL:=v_SQL ? ?' WHERE ROWNUM <= ' ? ?v_EndIndex;  
  7. v_SQLv_SQL:=v_SQL ? ?')WHERE RN >= ' ? ?v_StartIndex;  
  8. open v_cur for v_SQL;  
  9. end P_QuerySplit;   

上述的相关内容就是对ibatis调用Oracle分页存储过程的描述,希望会给你带来一些帮助在此方面。

【编辑推荐】

  1. 如何解决Oracle死锁问题
  2. LTO归档解决方案容量、性能和功能介绍
  3. Oracle多表关联中的update语句实际应用
  4. 实现Oracle传输表空间的实际功能解析
  5. Oracle rownum用法的归纳
责任编辑:佚名 来源: 博客园
相关推荐

2010-05-06 14:01:12

Oracle分页存储过

2009-07-21 14:57:41

iBatis中调用存储iBatis

2010-04-16 11:31:29

Oracle分页存储过

2010-04-29 17:31:56

Oracle存储过程

2009-07-21 13:50:00

iBATIS.NET调

2010-05-05 17:19:32

Oracle存储过程

2010-04-16 11:03:02

Oracle存储过程

2018-06-20 09:39:47

Oracle存储配置

2010-10-26 14:50:11

oracle存储过程

2009-03-03 11:51:54

微软数据库ACCESS

2011-06-17 17:37:16

JavaSQL Server

2011-05-17 15:13:59

oracle分页存储

2010-05-05 14:55:15

Oracle存储过程

2010-05-10 14:16:50

Oracle树结构

2009-07-22 15:58:34

JDBC调用Oracl

2010-11-10 15:16:14

Sql Server分

2011-04-15 10:56:22

2010-04-12 09:26:52

Oracle查询分页

2010-03-30 13:30:49

Oracle存储

2011-07-19 17:33:53

存储过程javaibatis
点赞
收藏

51CTO技术栈公众号