java 操作cursor数据库_Java连接各种数据库以及调用存储过程

准备工作:

1. 创建表

drop table T_TEST_PROCEDURE cascade constraints;

/*==============================================================*/

/*

Table: T_TEST_PROCEDURE

*/

/*==============================================================*/

create

table T_TEST_PROCEDURE (

ID

NUMBER(19) not null,

NAME

VARCHAR2(40),

AGE NUMBER(3),

constraint

PK_T_TEST_PROCEDURE primary key (ID)

);

2. 创建存储过程

无返回值的存储过程

CREATE OR REPLACE PROCEDURE

proctest (

ID IN NUMBER,

NAME IN VARCHAR2,

age

IN NUMBER

)

AS

BEGIN

INSERT INTO

t_test_procedure

(ID, NAME, age

)

VALUES (ID, NAME, age

);

END

proctest;

/

有非列表返回值的存储过程

CREATE OR REPLACE PROCEDURE

proc_returnnolist (

p_id IN INTEGER,

p_name OUT

VARCHAR2,

p_age OUT INTEGER

)

AS

BEGIN

SELECT NAME,

age

INTO p_name, p_age

FROM t_test_procedure

WHERE ID =

p_id;

END proc_returnnolist;

/

返回结果集的存储过程

要返回结果集,需要使用Oracle的package

CREATE OR REPLACE PACKAGE

test_proc_package

AS

TYPE testproccursor IS REF CURSOR;

END

test_proc_package;

存储过程

CREATE OR REPLACE PROCEDURE

proc_returnlist (

testproccursor OUT

test_proc_package.testproccursor

)

AS

BEGIN

OPEN

testproccursor

FOR

SELECT *

FROM

t_test_procedure;

END proc_returnlist;

/

用Java调用存储过程

1. 调用无返回值的存储过程

CallableStatement callableStmt =

con

.prepareCall("{call

proctest(?,?,?)}");

callableStmt.setInt(1,

2);

callableStmt.setString(2, "Stephen");

callableStmt.setInt(3,

27);

callableStmt.execute();

callableStmt.close();

System.out.println("Success");

2. 调用返回非列表的存储过程

CallableStatement callableStmt =

con

.prepareCall("call

proc_returnnolist(?,?,?)");

callableStmt.setInt(1,

3);

callableStmt.registerOutParameter(2,

Types.VARCHAR);

callableStmt.registerOutParameter(3,

Types.INTEGER);

callableStmt.execute();

String name =

callableStmt.getString(2);

int age = callableStmt.getInt(3);

callableStmt.close();

System.out.println("name:" + name + " age:" +

age);

3. 调用返回结果集的存储过程

CallableStatement callableStmt =

con

.prepareCall("call

proc_returnlist(?)");

callableStmt.registerOutParameter(1,

OracleTypes.CURSOR);

callableStmt.execute();

ResultSet rs =

(ResultSet) callableStmt.getObject(1);

while (rs.next())

{

System.out.println("name:" + rs.getString("name") + "

age:"

+

rs.getInt("age"));

}

rs.close();

callableStmt.close();

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/529393.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java 规格overview_《Java數據結構和算法》- OverView

Q: 不同數據結構的優缺點?數據結構優點缺點數組(Array)快速訪問,如果知道下標,就可以非常快地存取查找慢, 插入或刪除慢, 大小固定有序數組(OrderedArray)比無序的數組查找快插入或刪除慢,大小固定棧(Stack…

mysql 集群怎么卸载节点_Greenplum移除节点

基于某某原因,我们的Greenplum需要卸载一个节点(测试环境的Greenplum集群),由于该集群使用了很久,里面有许多开发所需要的数据,所以在卸掉一个节点后,还要保证数据不会丢失。当然,期间也遇到了点问题&#…

mysql2012更改表名_T-SQL入門攻略之13-修改数据表

--> Title : T-SQL入門攻略之13-修改数据表--> Author : wufeng4552--> Date : 2010-07-12修改表名与字段名—sp_rename--1修改表名SQL Server不直接提供修改表名的T-SQL语句,但是可以通过存储过程实现语法格式:sp_rename tablename,newtabl…

python中不论类的名字是什么歌_Python自动猜歌名,还愁排名上不去嘛?

前言相传,就在前几日,在网上闲逛时,刷到了一个猜歌的小程序。这个小程序通过播放歌曲部分片段,然后让用户来猜它的歌名,大概是这样的:作为一个脑热的听歌爱好者,于是他越陷越深,越刷…

java调用oracle存储过程_做一点,记一点 ~ Java调用Oracle存储过程

一、需求传入一个参数,返回一条或多条记录(列表)。二、实现步骤1. 编写Oracle存储过程。-- 声明包和包体的语句应该分两次执行,即使声明在前定义在后,如果一起执行依然会编译出错--调用能够返回多条记录的存储过程需要定义在包内--声明包及包…

java 从控制台读取_转载 java从控制台读取输入的方法

import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.Scanner; public class MainClass { public static void method1() { //使用Scanner Scanner scannernew Sca…

trace java_使用java动态字节码技术简单实现arthas的trace功能。

参考资料用过[Arthas]的都知道,Arthas是alibaba开源的一个非常强大的Java诊断工具。不管是线上还是线下,我们都可以用Arthas分析程序的线程状态、查看jvm的实时运行状态、打印方法的出入参和返回类型、收集方法中每个代码块耗时,甚至可以监控…

顺时针小球圆周运动Java编程_如何使用CSS实现圆周运动小球的实例

我们时常在页面中见到一些动画效果,这些动画效果,很多可以仅通过CSS来实现。在这里我们用到了CSS3的animation属性。animation 属性是一个简写属性,用于设置六个动画属性:animation-name 规定需要绑定到选择器的 keyframe 名称。a…

java swing 外观框架_【GUI】一、Swing外观框架BeautyEye使用

一、Swing外观框架BeautyEye使用1.1 导包1.2 使用BeautyEye L&Fpublic static void main(String[] args) {EventQueue.invokeLater(new Runnable() {public void run() {// 国人牛逼主题,值得学习// 初始化字体InitGlobalFont(new Font("微软雅黑", F…

static详解java_java中static作用详解

static表示“全局”或者“静态”的意思,用来修饰成员变量和成员方法,也可以形成静态static代码块,但是Java语言中没有全局变量的概念。被static修饰的成员变量和成员方法独立于该类的任何对象。也就是说,它不依赖类特定的实例&…

java基础案例教程前4章知识点_java学习记录4 Java基础知识点

java学习记录4 Java基础知识点1. 注释单行注释使用“//”开头,后面是注释的内容一般在要注释的语句的上面加注释多行注释以“/*”开头,以“*/”结尾可以做行内注释不可嵌套使用文档注释以“/**”开头,以“*/”结尾用来给类和方法做注释&#…

打印狗的健康值Java_嵌入式狗的JAVA之路 HTML 补课

学了JAVA WEB应用,补充一下HTML的标签,常用的,不然页面都画不出来了~~test 标题,h1h2h3 3个字号test 段落link 链接 使用 Target 属性,你可以定义被链接的文档在何处显示。下面的这行会在新窗口打开文档:Vi…

mysql 表2符合表1_MYSQL-表1和表2中所有可能性的所有行

表用户id, name1, Jay Bob2, An Other表格页id, name, html1, Welcome, Welcome to this page2, Goodbye, Thanks for visiting表user_pages **存储页面的用户特定版本**user_id, page_id, html1, 1, User id 1 Welcome page我基本上需要一个查询,该查询将为我返回以下数据集-即…

java引擎组件_Java 脚本引擎入门

Java Script EngineJava 脚本引擎可以将脚本嵌入Java代码中,可以自定义和扩展Java应用程序,自JDK1.6被引入,基于Rhino引擎,JDK1.8后使用Nashorn引擎,支持ECMAScript 5,但后期还可能会换。脚本引擎包位于jav…

python 角度传感器模拟_python树莓派红外反射传感器

本文实例为大家分享了python树莓派红外反射传感器的程序,供大家参考,具体内容如下1、工具rpi3,微雪ARPI600,Infrared Reflective Sensor2、基本原理Infrared Reflective Sensor 输出数字和模拟信号模拟信号通过ARPI600上的AD转换芯…

JAVA awt eventqueue_线程“AWT-EventQueue-1”中的异常java.lang.NullPointerException

嗨,我收到错误Exception in thread "AWT-EventQueue-1" java.lang.NullPointerExceptionat P6.itemStateChanged(P6.java:215)at javax.swing.AbstractButton.fireItemStateChanged(AbstractButton.java:2023)at javax.swing.AbstractButton$Handler.item…

java构造方法赋值内存图_java 面向对象(九):类的结构:构造器(一)简介;属性赋值顺序;JavaBean的概念...

1.构造器(或构造方法):Constructor构造器的作用:* 1.创建对象* 2.初始化对象的信息2.使用说明:* 1.如果没显式的定义类的构造器的话,则系统默认提供一个空参的构造器* 2.定义构造器的格式:权限修饰符 类名(形参列表){}…

java 集合modcount_源码|jdk源码之LinkedList与modCount字段

链表是对上一篇博文所说的顺序表的一种实现。与ArrayList思路截然不同,链表的实现思路是:不同元素实际上是存储在离散的内存空间中的。每一个元素都有一个指针指向下一个元素,这样整个离散的空间就被“串”成了一个有顺序的表。从链表的概念来…

idea 新建ssm java ee_IDEA搭建SSM项目实现增删改查

首先打开IDEA,File—>New—>Project创建项目选择左侧导航栏里的Maven,勾上勾,选择webapp按如下图进行填写创建完成后进入项目,右下角弹出的提示点击右边的Enable Auto-Import,自动配置连接数据库,我用…

php mail centos_centos怎么发送邮件

一、安装sendmail与mail1、安装sendmail:1) centos下可以安装命令:yum -y install sendmail2) 安装完后启动sendmail命令:service sendmail start2、安装mail安装命令:yum install -y mailx二、发送邮件1、通过文件内容发送发送命…