oracle数据库的调用存储过程,Java:在oracle数据库中调用存储过程

为了能够捕获Oracle数据库中的过程返回,请尝试此操作.

public static void main(String[] args) {

try {

Class.forName("oracle.jdbc.driver.OracleDriver");

String url = "jdbc:oracle:thin:@localhost:1521:xe";

Connection con = DriverManager.getConnection(url, db_user, password);

System.out.println("Connected to database");

SimpleDateFormat simpleDateFormat = new SimpleDateFormat("dd/MM/yyyy");

Date now = new java.sql.Date(simpleDateFormat.parse("12/02/2001").getTime());

String command = "{call SALDOS(?,?)}";

CallableStatement cstmt = con.prepareCall(command);

cstmt.registerOutParameter(2, Types.DECIMAL);

cstmt.setDate(1, now);

cstmt.execute();

Double str = cstmt.getDouble(2);

cstmt.close();

System.out.println("Retorno: " + str);

} catch (Exception e) {

e.printStackTrace();

}

}

如果您使用不同的返回Map SimpleJdbcCall这样:

SimpleJdbcCall call = Util.getSimpleJdbcCallInstance();

call.setProcedureName("PROCED_CONDOMINIAL");

call.declareParameters(

new SqlParameter("CONDOMINIO", Types.VARCHAR),

new SqlParameter("BLOCO", Types.VARCHAR),,

new SqlOutParameter("P_NUMERO", Types.NUMERIC),

new SqlOutParameter("P_LOG", Types.VARCHAR));

Map parametros = new HashMap();

parametros.put("CONDOMINIO_IC", descricaoCondominio);

parametros.put("BLOCO_IC", imovelCondominial.getBloco());

Map out = call.execute(parametros);

BigDecimal chave = (BigDecimal) out.get("P_NUMERO");

imovelCondominial.setId(chave.longValue());

和程序的声明

create or replace PROCEDURE PROCED_CONDOMINIAL

(CONDOMINIO VARCHAR2,

BLOCO VARCHAR2,

NUMERO OUT NUMBER,

LOG OUT VARCHAR2) -- PARAMETROS DE SAIDAS (OUT).-

在这里工作.看看这个博客.

在Oracle 10xe和11xe上测试过.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值