Oracle数据库基本操作 (五) —— 使用java调用存储过程
一、环境准备
登录Oracle数据库scott账号,利用emp进行操作。
1、创建 proc_getyearsal 存储过程
- -- 获取指定员工年薪
- create or replace procedure proc_getyearsal(vempno in number,vyearsal out number)
- is
- begin
- select sal*12+nvl(comm,0) into vyearsal from emp where empno=vempno;
- end;
2、创建 proc_gettemps 存储过程(游标)
- create or replace procedure proc_gettemps(vemps out sys_refcursor)
- is
- BEGIN
- open vemps for select * from emp where deptno = 20;
- end;
3、导入数据库驱动包 —— ojdbc14.jar
二、java代码示例
- package com.pri.test;
- public class TestProcedure {
- /*
- java调用存储过程模板(一)
- 获取单值操作
- */
- @Test
- public void test01() throws Exception {
- //1.注册驱动
- Class.forName("oracle.jdbc.driver.OracleDriver");
- //2.获取连接
- String url = "jdbc:oracle:thin:@10.211.55.29:1521/orcl";
- String user = "zhangsan";
- String password = "zs123";
- Connection conn = DriverManager.getConnection(url, user, password);
- //3.获取执行SQL的对象
- String sql = "{call proc_getyearsal(?,?)}";
- CallableStatement callableStatement = conn.prepareCall(sql);
- //3.1 设置输出参数
- callableStatement.setInt(1,7369);
- //3.2 注册输出类型
- callableStatement.registerOutParameter(2, Types.DOUBLE);
- //4.执行SQL
- callableStatement.execute();
- //5.执行结果
- double yearsal = callableStatement.getDouble(2);
- System.out.println("年薪:"+yearsal);
- //6.释放资源
- callableStatement.close();
- conn.close();
- }
- /*
- java调用存储过程模板(二)
- 多行记录(游标)操作
- */
- @Test
- public void test03() throws Exception {
- //1.注册驱动
- Class.forName("oracle.jdbc.driver.OracleDriver");
- //2.获取连接
- String url = "jdbc:oracle:thin:@10.211.55.29:1521/orcl";
- String user = "zhangsan";
- String password = "zs123";
- Connection conn = DriverManager.getConnection(url, user, password);
- //3.获取执行SQL的对象
- String sql = "{call proc_gettemps(?)}";
- CallableStatement callableStatement = conn.prepareCall(sql);
- //3.1 注册输出类型
- callableStatement.registerOutParameter(1, OracleTypes.CURSOR);
- //4.执行SQL
- callableStatement.execute();
- //5.获取结果
- System.out.println(callableStatement.getClass().getName());
- // T4CCallableStatent call2 = () callableStatement;
- OracleCallableStatement call2 = (OracleCallableStatement) callableStatement;
- ResultSet rs = call2.getCursor(1);
- while(rs.next()){
- System.out.println(rs.getObject("empno"));
- System.out.println(rs.getObject("ename"));
- System.out.println(rs.getObject("sal"));
- System.out.println("------------------------");
- }
- //6.释放资源
- rs.close();
- callableStatement.close();
- conn.close();
- }
- }
Oracle数据库基本操作 (五) —— 使用java调用存储过程的更多相关文章
- clob字段的值插入和查询N种方法【包括java调用存储过程传入clob参数】
import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.IOException; import jav ...
- Oracle数据库基本操作(一) —— Oracle数据库体系结构介绍、DDL、DCL、DML
一.Oracle数据库介绍 1.基本介绍 Oracle数据库系统是美国ORACLE公司(甲骨文)提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器(CLIENT/SERVER)或B/ ...
- java调用存储过程(stored procedures)的HelloWorld例子
1.java调用存储过程(stored procedures)的HelloWorld程序 有点数据 库基础的人都知道.存储过程(stored procedures)和java没什么关系.它是一段纯粹的 ...
- Oracle数据库date类型与Java中Date的联系与转化
以下是对Java中的日期对象与Oracle中的日期之间的区别与联系做点说明,以期对大家有所帮助.new Date():分配 Date 对象并初始化此对象,以表示分配它的时间(精确到毫秒),就是系统当前 ...
- Oracle数据库基本操作(四) —— PLSQL编程
Procedure Language 实际上是Oracle对SQL语言的能力扩展,让SQL语言拥有了if条件判断,for循环等处理. 一.PLSQL基本语法 DECLARE -- 声明部分 变量名 变 ...
- 【转】java调用存储过程和函数
一.概述 如果想要执行存储过程,我们应该使用 CallableStatement 接口. CallableStatement 接口继承自PreparedStatement 接口.所以CallableS ...
- Java调用存储过程小结
学生在学习jdbc的时候,会问到怎么调用存储过程,现在将java调用oracle存储过程的示例总结如下.(关于调用sqlserver的存储过程将在下次进行小结请关注) 一:无返回值的存储过程 存储过程 ...
- Java 调用存储过程 返回结果集
这里使用Oracle数据库的thin连接. 下面是存储过程SQL 1 createorreplaceprocedure proc3(stid in student.stuid%type, stname ...
- java调用存储过程和函数
以对表test进行增,删,改,查进行说明:1.新建表test create table TEST ( TID NUMBER not null, TNAME VARCHAR2(32), TCODE VA ...
随机推荐
- 【git】——简单用法
git 更新远程代码到本地 git fetch origin master git merge origin/master 冲突: Your local changes to the followin ...
- linux安装scala环境
(安装scala的前提是已经安装好了jdk) 1.下载scala的安装包 wget https://scala-lang.org/files/archive/scala-2.11.0-M2.tgz 2 ...
- c语言求方阵的行列式、伴随矩阵算法
#include<stdio.h> #include<math.h> #define N 100 //N比输入的阶数大即可 int main() { int n,a[N][ ...
- SSAS 收藏
1.多事实表 SQL实现和SSAS中MDX实现的差异 2.层次结构 3.MDX常用几种查询对比 4.一段话理解 MDX中的Select .轴.COLUMNS.ROWS 5.[转载]MSDN-MDX#0 ...
- ltp-ddt eth过程中遇到的问题
eth_iperf_tcp ETH_S_PERF_IPERF_TCP_INTPACING_8K_1448B source 'common.sh'; iface=`get_eth_iface_name. ...
- Python基础部分的疑惑解析——运算符和数据类型(3)
补充上一篇: #! /user/bin/env python 代码内声明这一个就可以用1.py类似的文件直接执行,但是要在linux内加权限, 不需要在前面加python 1.py执行了.文件可以 ...
- pycharm连接数据库出现时区jdbc问题
unrecognized or represents more than one time zone. You must configure either the server or JDBC dri ...
- C#接口实现多态
我比较喜欢对感兴趣的理论进行反复的理解甚至理解背诵下来,接下来再复习一下什么叫多态(哈哈哈) 多态:在同一粒度视图下对相同类型的事物不做区别的统一操作 接下来看一下接口和引擎类是如何实现多态的: 一. ...
- Hexo博客系列(二)-在多台机器上利用Hexo发布博客
[原文链接]:https://www.tecchen.xyz/blog-hexo-env-02.html 我的个人博客:https://www.tecchen.xyz,博文同步发布到博客园. 由于精力 ...
- CF1083(Round #526 Div. 1) 简要题解
题目链接 https://codeforces.com/contest/1083 简要题目翻译 题解 A. The Fair Nut and the Best Path 可以忽略掉"任意时刻 ...