Oracle基础(五)pl/sql进阶(分页过程)
编写分页过程
1、无返回值的存储过程
比如 1、能够向book表加入书,
---建表
Create table book(bookId number,bookName varchar2(50),publishHouse
varchar2(50));
--编写过程 in
表示变量为输入值。假设不写默觉得输入值,而不是输出变量,out为输出值
Create or replace procedure sp_pro7(spBookId in number,spbookName in varchar2,sppublishHouse in varchar2)is
Begin
Insert into book valuse(spBookId ,spbookName,sppublishHouse );
End
---java
中怎样调用
Package com.sp;
Importjava.sql.*;
Publicclass Test1{
public static void main(string[] args){ try{
//1载入驱动
Class.forName("Oracle.jdbc.driver.OracleDriver");
Connetionct=DriverManger.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:myora1","scott","123");
//2创建callablestatement
Callablestatement cs=ct.preparecall(“{call sp_pro7(?,?,? )}”)。
//给?赋值
Cs.setInt(1,10);
Cs.setstring(2。“笑傲江湖”);
Cs.setstring(3,"人民出版社");
//运行
Cs.execute();; }
Catch(EXCEPTION E){
e.printstacktrace(); }
Finally{
关闭各个链接 } } }
2、有返回值的存储过程
比如输入书编号返回书姓名
Create or replace procedure sp_pro8(spno in number,spkName out varchar2,spsal
out varchar2) is
Begin
select ename
,spsal,into spName, spsal form emp where empno=spno;
End
在java中怎样调用
Package com.sp;
Importjava.sql.*;
Publicclass Test1{
public static void main(string[] args){ try{
//1载入驱动
Class.forName("Oracle.jdbc.driver.OracleDriver");
Connetionct=DriverManger.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:myora1","scott","123");
//2创建callablestatement
Callablestatement cs=ct.preparecall(“{call sp_pro8(?,?)}”);
//给?赋值
Cs.setInt(1,7788);
Cs.registerOutParemeter(2,oracle.jdbc.oracleTyps.varchar)//运行
Cs.registerOutParemeter(3,oracle.jdbc.oracleTyps.double)//运行 //oracle.jdbc.oracleTyps.varchar 表示运行的类型
Cs.execute();
//取出返回值,要注意?顺序
String name=sc.getstring(2);
String job=cs.getstring(3);
System.out.println(“7788的名字”+name +“7788的工资”+sal); }
Catch(EXCEPTION E){
e.printstacktrace(); }
Finally{
关闭各个链接 } } }
3、有返回值的存储过程,以列表结果集的形式返回
oracle存储过程本身没有返回时用out參数替代的。集合须要用package
--建立包,定义类型test_cursor
Create or replace packagetestpackage as
Typetest_cursur is
ref cursor;
End testpackage
建立存储过程
Create or repalce procedure sp_pro9(spNo in number,P_cursor out tespackage,test_cursor) is
begin
Open p_cursor for select *from emp where depto-spNo;
End;
--怎样在java中调用
Package com.sp;
Importjava.sql.*;
Publicclass Test1{
public static void main(string[] args){ try{
//1载入驱动
Class.forName("Oracle.jdbc.driver.OracleDriver");
Connetionct=DriverManger.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:myora1","scott","123");
//2创建callablestatement
Callablestatement cs=ct.preparecall(“{call sp_pro9(?,? )}”);
//给?赋值
Cs.setInt(1,10);
Cs.registerOutParemeter(2,oracle.jdbc.oracleTypes.cursor)
//运行
Cs.execute();
//取出返回值,要注意?顺序
ResultSet rs=(ResultSet)cs.getObject(2);
While (rs.next()){
system.out.println(rs.getInt(1)+""+rs.getString(2));
} }
Catch(EXCEPTION E){
e.printstacktrace();
}
Finally{
关闭各个链接 } } }
4、----oracle的分页规律介绍
Sql>select t1.*。
rownum rn from(select * from emp) t1;
Sql>select t1.*,
rownum rn from(select * from emp) t1 where rownum<=10;
--在分页的时候。能够
Select *from(
Sql>select t1.*,
rownum rn from(select * from emp) t1where rownum<=10;) where rn>=6;
--开发一个包
Create or replace package testpackage as
Typetest_cursur is
ref cursor;
End testpackage
5、--编写分写的过程 分页并按工资排序
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_endnumber:=Pagenow *Pagesize ;
Begin
--运行部分
v_sql:='Select * from(
Sql>select t1.*,
rownum rn from(select * from '||tableName||' order by sal) 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;
Executeimmediate 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;
--使用java測试
Package com.sp;
Importjava.sql.*;
Public class Test1{
public static void main(string[] args){ try{
//1载入驱动<span style="font-family: Arial, Helvetica, sans-serif;"> </span>
Class.forName("Oracle.jdbc.driver.OracleDriver");<span style="font-family: Arial, Helvetica, sans-serif;"> </span>
Connetionct=DriverManger.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:myora1","scott","123");
//2创建callablestatement
Callablestatement cs=ct.preparecall(“{call fenye(?,? ,?,? ,?,? )}”)。
//给?赋值
Cs.setString(1,"emp"); 表
Cs.setInt(2,5);每页大小
Cs.setInt(3,2);第2页
//接受总记录数
Cs.registerOutParemeter(4,oracle.jdbc.oracleTypes.integer)//运行
//注冊总页数
Cs.registerOutParemeter(5,oracle.jdbc.oracleTypes.integer)//运行
//注冊返回的结果集
Cs.registerOutParemeter(6,oracle.jdbc.oracleTypes.cursor)//运行
Cs.execute();
//取出总记录数,这里注意。getint(4)中4是由该參数的位置决定 Int rowNum=cs.getInt(4);
Int pageCount=cs.getint(5);
Resultset rs=(resultset)cs.getobject(6); //显示下是否正确
System.out.println("rownum="+ rownum);
System.out.println("总页数:")+pagecount);
While(rs.next()){ system.out.println("编号:"+rs.getInt(1) +“名字”+rs.getstring(20)+"薪水"。
}
} }
Catch(EXCEPTION E){
e.printstacktrace(); }
Finally{
关闭各个链接 } } }
看似非常复杂一个分页过程,通过一步步由简到繁的分解,由无返回值的存储过程,到有返回值,进而到以集合形式作为返回值的存储过程,加上简单的分页算法。基于pl/sql中包,游标。mod语句,if分支语句。变量的定义,oder by子句组成。
学习的过程就是这样,一口一个胖子是不可能的。相同这也是人类认知的一个规律,由简到繁,在遇到复杂的问题要考虑怎样将它拆分成简单的,自己熟知的问题。一步步了解。
Oracle基础(五)pl/sql进阶(分页过程)的更多相关文章
- Oracle数据库之PL/SQL基础
介绍PL/SQL之前,先介绍一个图像化工具:Oracle SQL Developer 在oracle的开发过程中, 我们难免会使用第三方开发的软件来辅助我们书写SQL, pl/sql是一个不错的sql ...
- Oracle数据库之PL/SQL过程与函数
Oracle数据库之PL/SQL过程与函数 PL/SQL块分为匿名块与命名块,命名块又包含子程序.包和触发器. 过程和函数统称为PL/SQL子程序,我们可以将商业逻辑.企业规则写成过程或函数保存到数据 ...
- pl/sql进阶一控制结构
在任何计算机语言(c,java,c#,c++)都有各种控制语句(条件语句,循环结构,顺序控制结构…),在pl/sql中也存在这样的控制结构. 在本部分学校完毕后,希望大家达到: 1)使用各种if语句 ...
- 每周一书《Oracle 12 c PL(SQL)程序设计终极指南》
本周为大家送出的书是<Oracle 12 c PL(SQL)程序设计终极指南>,此书由机械工业出版社出版, 孙风栋,王澜,郭晓惠 著. 内容简介: <Oracle 12c PL/SQ ...
- Oracle数据库之PL/SQL程序设计简介
PL/SQL程序设计简介 一.什么是PL/SQL? PL/SQL是 Procedure Language & Structured Query Language 的缩写. ORACLE的SQL ...
- pl/sql进阶--例外处理
在pl/sql的执行过程中发生异常时系统所作的处理称为一个例外情况(exception).通常例外情况的种类有三种: 1.预定义的oracle例外情况oracle预定义的例外情况大约有24个,对于这种 ...
- 64位Oracle 11g 使用PL/SQL
Oracle 11g和PL/SQL安装完后,发现打开PL/SQL并不能连接Oracle数据库! [第一回合]完败! 先是在网上找解决方法,说是需要使用Net Configuration Assista ...
- oracle数据库之PL/SQL 块结构和组成元素
一.PL/SQL 块 (一)PL/SQL 程序由三个块组成,即声明部分.执行部分.异常处理部分 PL/SQL 块的结构如下: 1.DECLARE /* 声明部分: 在此声明 PL/SQL 用到的变量, ...
- ORACLE中的PL/SQL
一. 1.过程,函数,触发器是pl/sql编写. 2. 过程函数触发器是在Oracle中. 3.pl/sql是非常强大的数据库过 ...
随机推荐
- asp.net检查服务器上目录或文件是否存在示例
原文 asp.net检查服务器上目录或文件是否存在示例 asp.net为我们提供了文件系统对象了,对于目录与文件判断是否存在我们有System.IO.File.Exists与System.IO.Dir ...
- HTML5,微信开发原码社区
HTML5开发助手,快速查看HTML及javascript接口文档 http://www.9miao.com/thread-60966-1-1.html 简洁的手机wap公司产品展示网站模板下载htm ...
- openCV中cvSnakeImage()函数代码分析
/*M/////////////////////////////////////////////////////////////////////////////////////// // // IMP ...
- MFC 在对话框显示图片的多种方法
我们先从简单的开始吧.先分一个类: (一) 非动态显示图片(即图片先通过资源管理器载入,有一个固定ID) (二) 动态载入图片(即只需要在程序中指定图片的路径即可载入) 为方便说明,我们已经建好一 ...
- [置顶] 强大的JQuery
JQuery初识 为了简化JS的开发,一些JS库诞生了,JQuery就是其中的一个.JQuery是一个兼容多浏览器的Javascript框架.是轻量级的JS库.jQuery为用户提供了丰富的文档说明, ...
- 大话项目管理工具之Confluence篇
前言 前面的两篇文章,讲的都是代码层次上的项目管理工具.这篇文章打算介绍一下关于知识管理的工具,当然,它也属于项目管理中的一部分.说到知识管理,你想到了什么呢?织网?找节点?不错,这是个人的知识管理. ...
- Android中日志信息的打印方式
Android中日志信息的打印方式主要有以下7种: 1)System.out(i级别) 2)System.err(w级别) 3)Log.v 4)Log.d 5)Log.i 6)Log.w 7)Log. ...
- 14.3.2.1 Transaction Isolation Levels 事务隔离级别
14.3.2 InnoDB Transaction Model InnoDB 事务模型 14.3.2.1 Transaction Isolation Levels 事务隔离级别 14.3.2.2 au ...
- [ffmpeg 扩展第三方库编译系列] 关于须要用到cmake 创建 mingw32编译环境问题
我在这里给出我编译的样例 cmake -G"MinGW Makefiles" -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=& ...
- EasyUI初体验--右键弹框
在C/S中可能非常easy实现右键弹框,但在B/S中直到今天我才搞定,小小得瑟一下.只一个html页面,导入相关的Easy-UI类库就能搞定,Easy-UI类库下载地址 <!DOCTYPE ht ...