oracle入门(7)——存储过程
【本文介绍】
熟悉了PL/SQL语法后,实现java调用oracle存储过程才是主要目的。本文将介绍如何写存储过程,java如何调用存储过程。
【存储过程介绍】
抛开专业的描述,存储过程就是在数据库里面写了一些函数,我们在代码(如java)里面调用这些函数实现对数据库的操作,避免了数据库对SQL语句的解析,对于需要发送多条SQL语句才能完成的数据库操作功能来说,速度上升了一个档次。不过程序在操纵数据库这一块 的维护性会降低,因为存储过程是写在数据库,不是写在程序里。
【如何写有能传值 并且 有返回值(非返回列表)存储过程】
非返回列表的存储过程比较容易,直接在函数名后面带参数就好,同时赋予参数的类型。
下面举一个例子:
存储过程代码:
CREATE OR REPLACE
procedure serachUserMethod(para1 IN VARCHAR2, para2 OUT VARCHAR2)
as
BEGIN
select "user"."name" into para2 from "user" where "user"."name"=para1;
end;
java代码:
package com.zjm.www.test; import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.Types;
import java.util.Date; import org.junit.After;
import org.junit.Before;
import org.junit.Test; public class test { private static String driverclass="oracle.jdbc.driver.OracleDriver";
// 本地
private static String url="jdbc:oracle:thin:@localhost:1521:orcl";
private static String username="test";
private static String password="Aaa38324836"; private static String sql="";
private static Connection conn = null;
private static Statement stmt = null;
private static ResultSet rs = null;
private static CallableStatement proc = null;; @Before
public void before(){
try {
Class.forName(driverclass).newInstance(); //加载驱动
conn=DriverManager.getConnection(url,username,password); //获得连接
stmt=conn.createStatement();
} catch (Exception e) {
e.printStackTrace();
} } @After
public void after(){
try {
if(conn != null){
conn.close();
}
} catch (Exception e) {
e.printStackTrace();
}
try {
if(stmt != null){
stmt.close();
}
} catch (Exception e) {
e.printStackTrace();
}
try {
if(rs != null){
rs.close();
}
} catch (Exception e) {
e.printStackTrace();
} } /**
* 测试调用存储过程用时
* @throws SQLException
*/
@Test
public void getDateByMethod(){ int pre = (int) System.currentTimeMillis(); try {
// 调用存储过程,问号个数代表参数存储过程的个数,且顺序要一一对应
proc = conn.prepareCall("{ call serachUserMethod(?,?) }");
// 传值
proc.setString(1, "AAAFB7E4B4D14475AD994310EF62EBA7");
// 注册返回值
proc.registerOutParameter(2, Types.VARCHAR);
// 提交
proc.execute();
// 取出返回值
System.out.println(proc.getString(2)); } catch (SQLException e) {
e.printStackTrace();
} finally {
proc.close();
}
int post=(int) System.currentTimeMillis();
System.out.println("测试调用存储过程用时"+(post-pre));
}
}
注意,这里的proc.getString(2)中的数值2并非任意的,而是和存储过程中的 参数 列对应的,如果out是在第一个位置,那就是proc.getString(1),如果是第三个位置,就是proc.getString(3),当然也可以同时有多个返回值,那就是再多加几个out参数了。
【返回列表的存储过程】
通过上面的例子,返回普通的int ,Stirng 类型的参数还是没问题的,可是这永远不能满足需求,我们一般要的是返回数据库里一个表的所有属性?当然可以。
第一步:建包(游标)。
存储过程是不能直接返回一个对象(这个对象有N个属性)的,但它有另外一种方式,通过建立一个”指针“一样的”游标“ 指向某些数据,最后返回这个 ”游标“ ,我们就能顺着这个游标拿到我们想要的数据了。
create or replace package testpackage as
type Test_CURSOR is ref cursor;
end testpackage;
第二步:创建存储过程。
注意:返回参数的类型为我们刚刚建立的 ”游标“ 类型
create or replace procedure testc(p_cursor out testpackage.Test_CURSOR)
is
begin
open p_cursor for select * from T_AP_ZA_LYT_GNLK;
end testc;
第三步:java代码:
package com.zjm.www.test; import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.Types;
import java.util.Date; import org.junit.After;
import org.junit.Before;
import org.junit.Test; public class test { private static String driverclass="oracle.jdbc.driver.OracleDriver";
// 本地
private static String url="jdbc:oracle:thin:@localhost:1521:orcl";
private static String username="test";
private static String password="Aaa38324836"; private static String sql=""; // 记得表名要用""括起来
private static Connection conn = null;
private static Statement stmt = null;
private static ResultSet rs = null;
private static CallableStatement proc = null;; @Before
public void before(){
try {
Class.forName(driverclass).newInstance(); //加载驱动
conn=DriverManager.getConnection(url,username,password); //获得连接
stmt=conn.createStatement();
} catch (Exception e) {
e.printStackTrace();
} } @After
public void after(){
try {
if(conn != null){
conn.close();
}
} catch (Exception e) {
e.printStackTrace();
}
try {
if(stmt != null){
stmt.close();
}
} catch (Exception e) {
e.printStackTrace();
}
try {
if(rs != null){
rs.close();
}
} catch (Exception e) {
e.printStackTrace();
} }
@Test
public void getDateByMethod2(){
int pre = (int) System.currentTimeMillis(); try {
proc = conn.prepareCall("{ call testc(?) }");
// 注册返回值参数,注意是游标类型
proc.registerOutParameter(1,oracle.jdbc.OracleTypes.CURSOR);
proc.execute();
// 返回的数据存储在一个ResultSet里面
ResultSet rs = (ResultSet)proc.getObject(1);
while(rs.next())
{
// getString(...)里面填的对应数据库 表 的字段名
System.out.println("<tr><td>" + rs.getString("id") + "</td><td>"+rs.getString("name")+"</td></tr>");
}
proc.close();
} catch (SQLException e) {
e.printStackTrace();
} int post=(int) System.currentTimeMillis(); System.out.println("测试调用存储过程用时"+(post-pre));
} }
oracle入门(7)——存储过程的更多相关文章
- Oracle入门4-REF Cursor
Oracle入门4-REF Cursor 转自:http://blog.sina.com.cn/s/blog_55dbebb00100gxsc.html 自:http://blog.csdn.net/ ...
- Dapper完美兼容Oracle,执行存储过程,并返回结果集。
Dapper完美兼容Oracle,执行存储过程,并返回结果集. 这个问题,困扰了我整整两天. 刚刚用到Dapper的时候,感觉非常牛掰.特别是配合.net 4.0新特性dynamic,让我生成泛型集合 ...
- Oracle中执行存储过程call和exec区别
Oracle中执行存储过程call和exec区别 在sqlplus中这两种方法都可以使用: exec pro_name(参数1..); call pro_name(参数1..); 区别: 1. 但是e ...
- Oracle job procedure 存储过程定时任务
Oracle job procedure 存储过程定时任务 oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务. 一.查询系统中的job,可以查询视图 --相关视图 ...
- Oracle dbms_lock.sleep()存储过程使用技巧-场景-分析-实例
<Oracle dbms_lock.sleep()存储过程使用技巧>-场景-分析-实例 摘要:今天是2014年3月10日,北京,雾霾,下午组织相关部门开会.会议的结尾一名开发工程师找到了我 ...
- oracle 中的存储过程
oracle 中的存储过程 --oracle 中的存储过程, --不带任何参数的 CREATE OR REPLACE PROCEDURE PRO_TEST AS -- AS 和is 没有任何区别 ...
- 【转】Oracle job procedure 存储过程定时任务
原文:Oracle job procedure 存储过程定时任务 oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务. 一.查询系统中的job,可以查询视图 --相 ...
- oracle函数和存储过程有什么区别
oracle函数和存储过程有什么区别 1. 返回值的区别,函数有1个返回值,而存储过程是通过参数返回的,可以有多个或者没有 2.调用的区别,函数可以在查询语句中直接调用,而存储过程必须单独调用. 函数 ...
- Oracle通用分页存储过程的创建与使用
Oracle通用分页存储过程的创建与使用 1.创建Oracle包的定义.使用 REF CURSOR 数据类型来处理 Oracle 结果集.REF CURSOR 是一个指向 PL/SQL 查询所返回的结 ...
- 用sql语句导出oracle中的存储过程和函数
用sql语句导出oracle中的存储过程和函数: SET echo off ; SET heading off ; SET feedback off ; SPOOL 'C:/PRC.SQL' repl ...
随机推荐
- [Busybox]Busybox制作文件系统
问题: 1.目前busybox和bootstrap两种方案制作文件系统,哪种开发周期更短,更加简单? 2.如果需要在文件系统中添加某个package,要怎么做,如vim/udhcpd等? 转自:htt ...
- Am335x 应用层之SPI操作
SPI接口有四种不同的数据传输时序,取决于CPOL和CPHL这两位的组合.图1中表现了这四种时序, 时序与CPOL.CPHL的关系也可以从图中看出. 图1 CPOL是用来决定SCK时钟信号空闲时的电平 ...
- hdu4675 GCD of Sequence 莫比乌斯+组合数学
/** 题目:hdu4675 GCD of Sequence 链接:http://acm.hdu.edu.cn/showproblem.php?pid=4675 题意:给定n个数的a数组,以及m,k: ...
- CPU被夺走的三种状态 执行时间久了 IO操作让cpu等待 被优先级高的抢占
CPU被夺走的三种状态 执行时间久了 IO操作让cpu等待 被优先级高的抢占
- 超酷的JavaScript叙事性时间轴(Timeline)类库
在线演示 Timeline 是我见过的最酷的展示事件随时间发展的javascript实现.你可以基于时间使用讲故事的方式来创建时间轴特效,整个时间轴以幻灯的方式来展示,你可以穿插图片,视频或者是网站, ...
- OS X删除自带的safari和facetime等程序
打开终端 cd /Applications/ //在应用程序文件目录删除苹果自带的程序 sudo rm -rf Safari.app/ //删除safari浏览器 sudo rm -rf Mail.a ...
- 【UVa】Partitioning by Palindromes(dp)
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=27&page=sh ...
- db2 improt from coldel0x7c
db2 load from "C:\20110816\20110816_BankEnterpri seCA.txt" OF del modified by coldel0x7c r ...
- 模板,BFS
#include <stdio.h> #include <string.h> #include <queue> using namespace std; struc ...
- iOS开发之--字典快速赋值
以往在学习解析数据的时候,我们用的方法都是一个一个生命,然后加到字典里面,然后进行复制,那样的麻烦,而且也不能保证一次成功,不出错,我是遇到过多次key值的问题! 其实可以把复制的过程替换成一句话: ...