网站首页 > 技术文章 正文
概述
网上有很多实现分页的存储过程,刚好项目有这方面需求,顺便做个总结,记录下做备忘!
下面基于Oracle11g环境。
需求:编写一个存储过程,要求可以输入表名、每页显示记录数和当前页,返回总记录数、总页数和结果集
1、oracle的分页写法
select t1.*,rownum rn from (select * from emp) t1; select t1.*,rownum rn from (select * from emp) t1 where rownum<=10;
在分页时,大家可以把下面的sql语句当作一个模板使用
--查询第5行到第10行的数据(错误写法) select rownum, empno from (select rownum rn , empno from emp) a where a.rownum > 5 and a.rownum < 10; --查询第5行到第10行的数据(正确写法) select rownum, empno from (select rownum rn , empno from emp where rownum<10) a where a.rn>5;
2、编写存储过程
开发一个包,在该包中,定义类型test_cursor,是个游标
create or replace package testpackage as type test_cursor is ref cursor; end testpackage;
开始编写分页的过程
create or replace procedure fenye(tableName in varchar2, --表名 pageSize in number, --一页显示记录数 pageNow in number, --当前页 myrows out number, --总记录数 myPageCount out number, --总页数 p_cursor out testpackage.test_cursor --返回的记录集 ) is --定义部分 --定义sql语句 字符串 v_sql varchar2(1000); --定义两个整数 v_begin number := (pageNow - 1) * pageSize + 1; v_end number := pageNow * pageSize; begin --执行部份 v_sql := 'select * from (select t1.*,rownum rn from (select * from ' || tableName || ') t1 where rownum<=' || v_end || ') where rn>=' ||v_begin; --把游标和sql关联 open p_cursor for v_sql; --计算myrows和myPageCount --组织一个sql v_sql := 'select count(*) from ' || tableName; --执行sql,并把返回的值赋给myrows; execute immediate v_sql into myrows; --计算myPageCount if mod(myrows, PageSize) = 0 then myPageCount := myrows / PageSize; else myPageCount := myrows / PageSize + 1; end if; --关闭游标 close p_cursor; end;
这里还是有些瑕疵的,还得再改进下,后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注一下~
猜你喜欢
- 2024-11-06 Aloudata BIG 支持 Oracle/DB2 存储过程算子级血缘解析
- 2024-11-06 Oracle探究_JAVA存储过程_开发指引《上》
- 2024-11-06 直播预告丨如何实现Oracle存储过程到java的一键转化
- 2024-11-06 Oracle job 定时执行 存储过程 oracle数据库job定时任务
- 2024-11-06 Oracle存储过程和游标 oracle存储过程游标for循环例子
你 发表评论:
欢迎- 617℃几个Oracle空值处理函数 oracle处理null值的函数
- 610℃Oracle分析函数之Lag和Lead()使用
- 599℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 595℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 591℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 582℃【数据统计分析】详解Oracle分组函数之CUBE
- 572℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 560℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- PageHelper - 最方便的 MyBatis 分页插件
- 面试二:pagehelper是怎么实现分页的,
- MyBatis如何实现分页查询?(mybatis-plus分页查询)
- SpringBoot 各种分页查询方式详解(全网最全)
- 如何在Linux上运行exe文件,怎么用linux运行windows软件
- 快速了解hive(快速了解美国50个州)
- Python 中的 pyodbc 库(pydbclib)
- Linux搭建Weblogic集群(linux weblogic部署项目步骤)
- 「DM专栏」DMDSC共享集群之部署(一)——共享存储配置
- 故障分析 | MySQL 派生表优化(mysql pipe)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)