- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Oracle数据分页存储过程实现
本包中包括两个分页的存储过程,一个是通用的,而另一个是比较具体的。分页主要用到了游标和pl/sql中的rownum的概念。1 声明:CREATE OR REPLACE PACKAGE PACK_PAGE ISTYPE PAGE_CURSOR IS REF CURSOR;--定义游标PROCEDURE PAGINATION_PROC(P_TABLENAME VARCHAR2, --表名 P_PAGEINDEX NUMBER, --当前页码 P_PAGESIZE NUMBER, --每页记录数 P_PAGECOUNT OUT NUMBER, --总页数 P_TOTALCOUNT OUT NUMBER, --总记录数 v_CURSOR OUT PACK_PAGE.PAGE_CURSOR, --返回的结果集 P_WHERE VARCHAR2, --查询条件 P_ORDER_KEY VARCHAR2, --排序关键字(asc desc) P_ORDER_COLUMN VARCHAR2 --排序字段 ) ; PROCEDURE PAGINATION_WAP_DETAIL_PROC( P_PAGEINDEX NUMBER, --当前页码 P_PAGESIZE NUMBER, --每页记录数 P_WHERE VARCHAR2, --查询条件 P_SELECTCONTENT VARCHAR2, --查询的内容 P_PAGECOUNT OUT NUMBER, --总页数 P_TOTALCOUNT OUT NUMBER, --总记录数 V_CURSOR OUT PACK_PAGE.PAGE_CURSOR --返回的结果集 );END PACK_PAGE;2:具体实现:CREATE OR REPLACE PACKAGE BODY PACK_PAGE IS PROCEDURE PAGINATION_PROC(P_TABLENAME VARCHAR2, --表名 P_PAGEINDEX NUMBER, --当前页码 P_PAGESIZE NUMBER, --每页记录数 P_PAGECOUNT OUT NUMBER, --总页数 P_TOTALCOUNT OUT NUMBER, --总记录数 v_CURSOR OUT PACK_PAGE.PAGE_CURSOR, --返回的结果集 P_WHERE VARCHAR2, --查询条件 P_ORDER_KEY VARCHAR2, --排序关键字(asc desc) P_ORDER_COLUMN VARCHAR2 --排序字段 ) IS V_PAGEINDEX NUMBER; --当前页 V_PAGESIZE NUMBER; --每页记录数 V_STARTCUR NUMBER; --游标开始 V_ENDCUR NUMBER; --游标结束 V_SQL VARCHAR2(2000); --保存sql的变量 BEGIN V_SQL := select count(*) from || P_TABLENAME; IF P_WHERE IS NOT NULL OR P_WHERE THEN V_SQL := V_SQL || where || P_WHERE; END IF; EXECUTE IMMEDIATE V_SQL INTO P_TOTALCOUNT; --查询总记录数 P_PAGECOUNT := CEIL(P_TOTALCOUNT / P_PAGESIZE); --计算总页数 V_PAGESIZE := P_PAGESIZE; IF V_PAGESIZE 0 THEN --判断当前页大小否小于0 V_PAGESIZE := 0; END IF; V_PAGEINDEX := P_PAGEINDEX; IF V_PAGEINDEX 0 THEN --判断当前页是否小于0 V_PAGEINDEX := 0; END IF; IF V_PAGEINDEX P_PAGECOUNT THEN --判断当前页是否超过最大页 V_PAGEINDEX := P_PAGECOUNT; END IF; V_STARTCUR := (V_PAGEINDEX - 1) * V_PAGESIZE + 1; --计算游标开始位置 V_ENDCUR := V_PAGEINDEX * V_PAGESIZE; --计算游标结束位置 V_SQL := select * from (select rownum,t.* from (select * from || P_TABLENAME; --sql语句的开始部分 IF P_WHERE IS NOT NULL OR P_WHERE THEN --判断是否有查询的条件传来
您可能关注的文档
最近下载
- 《输液导管相关静脉血栓形成防治中国专家共识》解读PPT课件.pptx VIP
- 高中英语_Being funny without saying a word教学课件设计.ppt
- 2024版育婴师培训全套课件完整版.docx VIP
- 子网掩码相关教学 子网掩码快速算法.doc VIP
- 什么什么踏地四字成语.docx VIP
- 力士乐卷扬减速机制动器安装拆解图文.pdf VIP
- 新能源汽车充电系统检修:车载充电机的认知与检修PPT教学课件.pptx
- 2025年度食品安全风险日管控、周排查、月调度记录表.pdf VIP
- (新版)消防设施操作员(初级)消防设施操作-考试题库(含答案).docx VIP
- 掘锚一体机检修工操作规程.docx VIP
文档评论(0)