- 浏览: 386126 次
- 性别:
- 来自: 合肥
文章分类
- 全部博客 (314)
- java (132)
- 生活 (13)
- javase模式 (6)
- weblogic (4)
- jquery (5)
- sql (21)
- ecside (1)
- el (3)
- css (5)
- spring (7)
- ireport (2)
- linux (14)
- struts2 (2)
- jstl (1)
- rmi (1)
- rose (9)
- js (6)
- swing (4)
- webservice (1)
- jboss (1)
- ejb3 (2)
- xml (1)
- 线程 (9)
- socket (3)
- jms (2)
- tomcat (10)
- 领域驱动 (3)
- json (3)
- 权限 (2)
- jvm (1)
- 书籍 (1)
- eclipse RCP (0)
- 数据库设计 (10)
- 软件分析建模 (5)
- 分析建模 (3)
- hibernate jpa (5)
- Java 获取系统信息,包括CPU使用率、硬盘大小、网卡状态、系统信息等 (1)
- 项目管理 (2)
- 财务 (0)
- oracle (2)
- 需求 (2)
- rcp gef (0)
- c++ (1)
- hadoop (2)
- BIGDATA (3)
- c (6)
最新评论
-
lh_kevin:
...
jpa 注解 -
一别梦心:
你好,我也遇到此问题了。就你贴的那段代码,你说了两种解决方式, ...
Hibernate的Antlr在Weblogic中产生Jar冲突的历史缘故以及解决办法 -
fireinjava:
...
el表达式 -
宋建勇:
...
JSON: property "xxx" has no getter method in class "..." -
handawei:
有道理,jpa是orm框架的java标准,它关注的是对象到关系 ...
jpa 注解
转载:http://developer.51cto.com/art/200906/130448.htm
创建需要的测试表:create table Test(tidvarchar2(10),tnamevarchar2(10));
第一种情况:无返回值.
- create or replace proceduretest_a(param1invarchar2,param2invarchar2)as
- begin
- insert into test value(param1,param2);
- end;
Java调用代码:
- package com.test;
- import java.sql.*;
- import java.io.*;
- import java.sql.*;
- public class TestProcA
- {
- public TestProcA(){
- }
- public static void main(String[]args)
- {
- ResultSet rs=null;
- Connection conn=null;
- CallableStatement proc=null;
- try{
- Class.forName("oracle.jdbc.driver.OracleDriver");
- conn=DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:test","test","test");
- proc=conn.prepareCall("{calltest_a(?,?)}");
- proc.setString(1,"1001");
- proc.setString(2,"TestA");
- proc.execute();
- }catch(Exceptione){
- e.printStackTrace();
- }finally{
- try{
- if(null!=rs){
- rs.close();
- if(null!=proc){
- proc.close();
- }
- if(null!=conn){
- conn.close();
- }
- }
- }catch(Exceptionex){
- }
- }
- }
- }
第二种情况:有返回值的存储过程(返回值非列表).
存储过程为:
- create or replace procedur etest_b(param1invarchar2,param2outvarchar2)
- as
- begin
- select tname into param2 from test where tid=param1;
- end;
Java调用代码:
- package com.test;
- import java.sql.*;
- import java.io.*;
- import java.sql.*;
- public class TestProcB
- {
- public TestProcB(){
- }
- public static void main(String[]args)
- {
- Connection conn=null;
- CallableStatement proc=null;
- try{
- Class.forName("oracle.jdbc.driver.OracleDriver");
- conn=DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:test","test","test");
- proc=conn.prepareCall("{calltest_b(?,?)}");
- proc.setString(1,"1001");
- proc.registerOutParameter(2,Types.VARCHAR);
- proc.execute();
- System.out.println("Outputis:"+proc.getString(2));
- }catch(Exceptione){
- e.printStackTrace();
- }finally{
- try{
- if(null!=proc){
- proc.close();
- }
- if(null!=conn){
- conn.close();
- }
- }catch(Exceptionex){
- }
- }
- }
- }
第三种情况:返回列表.
由于oracle存储过程没有返回值,它的所有返回值都是通过out参数来替代的,列表同样也不例外,但由于是集合,所以不能用一般的参数,必须要用pagkage了.要分两部分来写:
- create or replace packaget package as
- typet_cursorisrefcursor;
- proceduretest_c(c_refoutt_cursor);
- end;
- createorreplacepackagebodytpackageas
- proceduretest_c(c_refoutt_cursor)is
- begin
- openc_refforselect*fromtest;
- endtest_c;
- endtpackage;
Java调用代码:
- package com.test;
- import java.sql.*;
- import java.io.*;
- import java.sql.*;
- public class TestProcB
- {
- public TestProcB(){
- }
- publics tatic void main(String[]args)
- {
- Connection conn=null;
- CallableStatement proc=null;
- ResultSet rs=null;
- try{
- Class.forName("oracle.jdbc.driver.OracleDriver");
- conn=DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:test","test","test");
- proc=conn.prepareCall("{?=calltpackage.test_b(?)}");
- proc.registerOutParameter(1,OracleTypes.CURSOR);
- proc.execute();
- while(rs.next()){
- System.out.println(rs.getObject(1)+"\t"+rs.getObject(2));
- }
- }catch(Exceptione){
- e.printStackTrace();
- }finally{
- try{
- if(null!=rs){
- rs.close();
- if(null!=proc){
- proc.close();
- }
- if(null!=conn){
- conn.close();
- }
- }
- }catch(Exceptionex){
- }
- }
- }
- }
Hibernate调用oracle存储过程
- this.pnumberManager.getHibernateTemplate().execute(
- newHibernateCallback()...{
- public Object doInHibernate(Sessionsession)
- throws HibernateException,SQLException...{
- CallableStatementcs=session.connection().prepareCall("{callmodifyapppnumber_remain(?)}");
- cs.setString(1,foundationid);
- cs.execute();
- returnnull;
- }
- });
发表评论
-
字符串,Volatile
2013-03-18 12:01 1121转载:http://www.ibm.com/de ... -
qian rushi
2012-12-01 10:13 0唐攀,华清远见高级研 ... -
110道 C语言 题目 超经典中的经典
2012-10-21 08:57 0... -
LOG4J
2012-08-07 10:34 1036long4j配置 转载:http://www.iteye. ... -
jpa 注解
2011-12-20 09:23 11821转:http://blog.csdn.net/gdweijin ... -
jna
2011-11-29 17:28 1525... -
eclipse设置
2011-11-16 08:45 864转:http://www.iteye.com/topic/11 ... -
深入分析 Java I/O 的工作机制
2011-11-14 08:57 888... -
java获得计算机信息
2011-10-29 13:03 1366采用singar.jar实现,需要将sigar-x86-win ... -
java内存机制
2011-10-24 13:01 1278转. Java内存机制详解 Ja ... -
缓存技术
2011-09-27 13:28 814一个培训的ppt,是介绍缓存知识的。有兴趣的可以参考:缓存技术 ... -
单点登录
2011-09-26 08:37 1596了解单点登录:: 可以使 ... -
继承和组合的关系
2011-08-18 09:17 904个人工作的感触: 首先框架的编写是难度很大,而工具 ... -
导入导出,创建databaselink
2011-08-10 15:56 2126pl/sql导出表结构和表 ... -
小结一下
2011-08-04 10:20 862觉得程序层面上是:数据类型(int long string) ... -
分析建模
2011-07-17 20:13 866系统建模与分析。 -
Java浮点数的精确计算
2011-06-27 16:10 988... -
异常系统
2011-05-31 17:19 707http://www.iteye.com/topic/7217 ... -
权限管理
2011-01-27 09:30 1331... -
jvisualvm
2011-01-11 21:09 907可以查看远程 本地的jvm 有两种方式 jmx jstatd ...
相关推荐
### DB2 Java 存储过程相关知识点 #### 标题:DB2 Java 存储过程 **DB2 Java 存储过程** 主要探讨的是如何在 IBM DB2 数据库环境中利用 Java 编写存储过程。这涉及到 DB2 的一系列产品和服务,特别是与 Java 集成...
### JAVA存储过程详解 在Java开发中,存储过程是一种预编译并存储在数据库中的SQL脚本或程序,它可以接收参数、执行复杂的逻辑,并返回结果。利用Java来调用存储过程,可以极大地提高应用程序的性能和安全性。下面...
### Java存储过程使用方法介绍 #### 执行概览与背景 在现代数据库系统中,存储过程作为一种封装了复杂逻辑的数据处理单元,在提升应用程序性能、增强数据完整性及简化应用开发方面扮演着重要角色。传统的存储过程...
Java存储过程是Java编程语言与数据库交互的一种技术,主要用于执行在数据库中预编译的SQL语句和数据库特定的函数。在Java项目中,存储过程的使用可以提高应用程序的性能,减少网络传输,同时也可以增强安全性,因为...
【Java存储过程实现Oracle远程逻辑备份与恢复】 Oracle数据库是一个基于网络计算的系统,它内建了对Java的支持,包括Oracle JVM(Java Virtual Machine),这使得开发者能够在数据库服务器端执行复杂的计算任务,...
### Java存储过程返回数据集 #### 标题与描述中的知识点概述 在Oracle数据库中,存储过程返回数据集的功能可以通过定义游标(RefCursor)来实现。与SQL Server相比,Oracle在这一方面需要额外的步骤来进行配置和...
Java存储过程的使用是数据库操作中的一个重要环节,它允许开发者在数据库端定义并执行复杂的业务逻辑,从而提高程序性能和数据处理效率。Oracle数据库(ORCL)是广泛使用的数据库管理系统,其中存储过程功能强大,...
Java 存储过程是数据库应用中的一个重要组成部分,尤其在DB2这种支持多种编程语言的数据库系统中,Java存储过程能够提供强大的功能和灵活性。DB2自带JDK并配置好环境,使得开发者可以直接编写和部署Java存储过程,...
Java存储过程在异构数据库访问中的应用 概述: 在异构数据库访问中,Java存储过程扮演着重要角色。随着企业信息化的发展,异构数据库的使用越来越普遍。为了实现跨数据库平台的数据共享,需要使用异构数据服务技术...
Oracle9i是一款由Oracle公司推出的基于网络计算的数据库系统,其独特之处在于集成了Oracle JVM(Java虚拟机),使得在数据库内部可以直接运行Java程序,即Java存储过程。这些过程允许开发人员利用Java语言来实现...
数据自动采集接口的实现需要依托于LabVIEW数据采集技术以及Java存储过程,在LabVIEW数据采集过程中引进Java存储过程,借助此接口可以实现实验室数据向船舶数字化平台的导入,有效节省人工操作环节。文章首先对LabVIEW...
【JAVA存储过程在Oracle数据库中的应用研究】 Oracle数据库作为全球广泛应用的关系型数据库系统,提供了丰富的功能,包括SQL和PL/SQL编程语言,用于处理数据库逻辑层面的开发。然而,对于某些复杂的非数据库逻辑...
**JAVA存储过程详解与示例** 在数据库管理中,存储过程是预编译的SQL语句集合,可以封装复杂的业务逻辑,并在需要时调用。在JAVA编程环境中,我们可以利用JDBC(Java Database Connectivity)来创建、执行和管理...
Java存储过程和函数是数据库操作中的重要组成部分,它们在Java应用程序与数据库交互时起到关键作用。存储过程是在数据库中预编译的SQL语句集合,而函数则返回一个值。这两种技术都允许开发者封装复杂的逻辑,提高...
在Oracle9i之前的版本,直接从Java存储过程返回ResultSet是不被支持的,因为缺乏ResultSet到REF CURSOR的映射机制。然而,Oracle9i引入了这种映射,使得Java存储过程能够返回ResultSet或作为OUT参数传递。尽管如此,...
### JAVA调用ORACLE存储过程通用类 #### 概述 在Java开发中,经常会遇到需要与数据库交互的情况,特别是当涉及到复杂的业务逻辑时,利用数据库的存储过程可以有效地提高程序性能并简化代码结构。本篇文章将详细...
在Java编程中,调用数据库的存储过程是常见的任务,特别是在处理复杂的业务逻辑或数据操作时。本实例将深入探讨如何使用Java来调用Oracle数据库中的存储过程。 首先,我们需要了解存储过程的基本概念。存储过程是预...
java mysql存储过程demo