JAVA操作ORACLE数据库的存储过程
一、任务提出
JAVA操作oracle11g存储过程实验需要完成以下几个实例:
1.调用没有返回参数的过程(插入记录、更新记录)
2.有返回参数的过程
3.返回列表的过程
4.返回带分页的列表的过程。
二、建立表和相应的存储过程
create table student (sno int ,sname varchar2(20),sage int);
--创建存储过程testa1
create or replace procedure testa1(para1 in int,para2 in varchar2,para3 in int)
is
begin
insert into student(sno,sname,sage) values(para1,para2,para3);
commit;
end;
/
--创建存储过程testa2
create or replace procedure testa2(para1 in int,para2 in int)
is
begin
update student set sage=para2 where sno=para1;
commit;
end;
/
--创建有返回参数的存储过程testb
create or replace procedure testb(para1 in int ,para2 out varchar2,para3 out int)
is
begin
select sname,sage into para2,para3 from student where sno=para1;
end;
--创建返回集合的存储过程:
--在oracle中,如果要返回集合必须是返回游标,不能是一张二维表。所以,要先建立包。
create or replace package testpack
is
type test_cursor is ref cursor;
end testpack;
/ create or replace procedure testc(p_cursor out testpack.test_cursor)
is
begin
open p_cursor for select * from student;
end;
/
--实现分页的存储过程
---ps 每页几个记录,cs第几页
create or replace procedure testd(ps int ,cs int ,p_cursor out testpack.test_cursor)
is
begin
open p_cursor for
select * from (select student.*,rownum rn from student) where rn>ps*(cs-1) and rn<=ps*cs;
end;
/
三、java操作调用上述存储过程
package com.oaj;
import java.sql.*; import com.sun.org.apache.xalan.internal.xsltc.compiler.util.Type; public class Test {
String driver="oracle.jdbc.driver.OracleDriver";
String strUrl="jdbc:oracle:thin:@localhost:1521:orcl";
ResultSet rs=null;
Connection conn=null; CallableStatement cstmt=null; public static void main(String[] args)
{
new Test().testPageSet(3,1);
}
public void testPageSet(int recordPerPage,int currentPage)
{
try
{
Class.forName(driver);
conn=DriverManager.getConnection(strUrl,"scott","scott");
cstmt=conn.prepareCall("{ call scott.testd(?,?,?)}");
cstmt.registerOutParameter(3, oracle.jdbc.OracleTypes.CURSOR);//指定是oracle里规定的类型
cstmt.setInt(1,recordPerPage);
cstmt.setInt(2, currentPage);
cstmt.execute();
rs=(ResultSet)cstmt.getObject(3); while(rs.next())
{
System.out.print("学号是:"+rs.getInt(1)+"的学生的名字是:"+rs.getString(2)+",年龄是:"+rs.getInt(3)+"\r\n");
}
}
catch(SQLException ex)
{
ex.printStackTrace();
}
catch(Exception ex)
{
ex.printStackTrace(); }
finally
{
try
{
if(cstmt!=null)
cstmt.close();
if(conn!=null)
{
conn.close();
conn=null;
} }
catch(SQLException ex)
{
ex.printStackTrace();
}
}
}
public void testOutResult()
{
try
{
Class.forName(driver);
conn=DriverManager.getConnection(strUrl,"scott","scott");
cstmt=conn.prepareCall("{ call scott.testc(?)}");
cstmt.registerOutParameter(1, oracle.jdbc.OracleTypes.CURSOR);//指定是oracle里规定的类型
cstmt.execute();
rs=(ResultSet)cstmt.getObject(1); while(rs.next())
{
System.out.print("学号是:"+rs.getInt(1)+"的学生的名字是:"+rs.getString(2)+",年龄是:"+rs.getInt(3)+"\r\n");
}
}
catch(SQLException ex)
{
ex.printStackTrace();
}
catch(Exception ex)
{
ex.printStackTrace(); }
finally
{
try
{
if(cstmt!=null)
cstmt.close();
if(conn!=null)
{
conn.close();
conn=null;
} }
catch(SQLException ex)
{
ex.printStackTrace();
}
}
}
public void testOutParameter(int inputSno)
{
try
{
Class.forName(driver);
conn=DriverManager.getConnection(strUrl,"scott","scott");
cstmt=conn.prepareCall("{ call scott.testb(?,?,?)}");
cstmt.setInt(1, inputSno);
cstmt.registerOutParameter(2, Types.VARCHAR);
cstmt.registerOutParameter(3, Types.INTEGER); cstmt.execute();
String name=cstmt.getString(2);
int age=cstmt.getInt(3); System.out.print("学号是:"+inputSno+"的学生的名字是:"+name+",年龄是:"+age);
}
catch(SQLException ex)
{
ex.printStackTrace();
}
catch(Exception ex)
{
ex.printStackTrace(); }
finally
{
try
{
if(cstmt!=null)
cstmt.close();
if(conn!=null)
{
conn.close();
conn=null;
} }
catch(SQLException ex)
{
ex.printStackTrace();
}
}
}
public void testNoOutParameterUpdate(int inputeSno,int inputSage)
{
try
{
Class.forName(driver);
conn=DriverManager.getConnection(strUrl,"scott","scott");
cstmt=conn.prepareCall("{ call scott.testa2(?,?)}");
cstmt.setInt(1, inputeSno);
cstmt.setInt(2, inputSage);
cstmt.execute();
System.out.println("执行成功!");
}
catch(SQLException ex)
{
ex.printStackTrace();
}
catch(Exception ex)
{
ex.printStackTrace(); }
finally
{
try
{
if(cstmt!=null)
cstmt.close();
if(conn!=null)
{
conn.close();
conn=null;
} }
catch(SQLException ex)
{
ex.printStackTrace();
}
}
}
public void testNoOutParameterInsert(int a,String b,int c)
{
try
{
Class.forName(driver);
conn=DriverManager.getConnection(strUrl,"scott","scott");
cstmt=conn.prepareCall("{ call scott.testa1(?,?,?)}");
cstmt.setInt(1, a);
cstmt.setString(2, b);
cstmt.setInt(3, c);
cstmt.execute();
}
catch(SQLException ex)
{
ex.printStackTrace();
}
catch(Exception ex)
{
ex.printStackTrace(); }
finally
{
try
{
if(cstmt!=null)
cstmt.close();
if(conn!=null)
{
conn.close();
conn=null;
} }
catch(SQLException ex)
{
ex.printStackTrace();
}
}
}
}
JAVA操作ORACLE数据库的存储过程的更多相关文章
- Java操作Oracle数据库以及调用存储过程
操作Oracle数据库 publicclass DBConnection { //jdbc:oracle:thin:@localhost:1521:orcl publicstaticf ...
- Java 操作Oracle数据库
import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import ...
- JAVA操作Oracle数据库中的事务
实验1: create table yggz(code int, salary number(7,2)); insert into yggz values(1, 1000); insert into ...
- Java java jdbc thin远程连接并操作Oracle数据库
JAVA jdbc thin远程连接并操作Oracle数据库 by:授客 QQ:1033553122 测试环境 数据库:linux 下Oracle_11g_R2 编码工具:Eclipse 编码平台:W ...
- loadrunner 脚本开发-调用java jar文件远程操作Oracle数据库测试
调用java jar文件远程操作Oracle数据库测试 by:授客 QQ:1033553122 测试环境 数据库:linux 下Oracle_11g_R2 Loadrunner:11 备注:想学ora ...
- dos命令行连接操作ORACLE数据库
C:\Adminstrator> sqlplus "/as sysdba" 查看是否连接到数据库 SQL> select status from v$instance; ...
- java 操作Oracle 批量入库的问题
java 操作Oracle 批量入库的问题 先说下我运行的环境: Windows7 64位操作系统 (四核)Intel i5-2300 CPU @2.80GHz 内存4G 硬盘1T Jdk1.6+My ...
- 在.NetCore(C#)中使用ODP.NET Core+Dapper操作Oracle数据库
前言 虽然一直在说"去IOE化",但是在国企和政府,Oracle的历史包袱实在太重了,甚至很多业务逻辑都是写在Oracle的各种存储过程里面实现的-- 我们的系统主要的技术栈是Dj ...
- Java操作Oracle
public class DBCon { // 数据库驱动对象 public static final String DRIVER = "oracle.jdbc.driver.OracleD ...
随机推荐
- 用css进行布局
用css进行布局 一,开始布局的注意事项 1.作为最佳实践,应把html(内容)和css(显示)分离: 2.网站设计主要有两大类型:固定宽度(基于像素)和响应式(也称流式,使用百分数定义) 二,构建 ...
- JQuery------Select标签的各种使用方法
optioin属性(value) <option value='>Hello</option> option的点击事件 <select class="s-one ...
- idea community 配置已有的scala工程
- sphinx :undefined reference to `libiconv' 报错解决办法
sphinx :undefined reference to `libiconv' 报错解决办法 2013-11-30 21:45:39 安装sphinx时不停报错...郁闷在make时报错,错误 ...
- 基本药目录sop
http://db.yaozh.com/basicdir 基本药物 编辑 "基本药物"的概念, 由世界卫生组织于1977年提出,指的是能够满足基本医疗卫生需求,剂型适宜.保证供应. ...
- easyUI datagrid editor扩展dialog
easyUI datagrid简单使用:着重两点1.editor对象的click事件:2.将dialog窗体内的值填写到当前正编辑的单元格内 <!DOCTYPE html> <htm ...
- 微软.NET序列化格式
官方文档 https://msdn.microsoft.com/en-us/library/cc236844.aspx 对比 http://www.codeproject.com/Articles/3 ...
- AssetBundle in Unity 5.0
http://forum.unity3d.com/threads/new-assetbundle-build-system-in-unity-5-0.293975/
- Mixing ASP.NET and MVC routing
Here is the solution I settled on. I installed the NuGet Microsoft.AspNet.FriendlyUrls package. Then ...
- JS验证URL正则
方法一: function fIsUrL(sUrl) { var sRegex = '^((https|http|ftp|rtsp|mms)?://)' + '?(([0-9a-z_!~*\'().& ...