java – StoredProcedureCall 1x Varchar输出1x光标输出
发布时间:2020-12-15 00:35:08 所属栏目:Java 来源:网络整理
导读:我的问题可能有点令人困惑.我有一个问题,我正在用 Java调用StoredProcedureCall的过程,例如: StoredProcedureCall call = new StoredProcedureCall(); call.setProcedureName("test"); call.addNamedArgument("p_year"); call.addNamedArgument("p_rel"); c
我的问题可能有点令人困惑.我有一个问题,我正在用
Java调用StoredProcedureCall的过程,例如:
StoredProcedureCall call = new StoredProcedureCall(); call.setProcedureName("test"); call.addNamedArgument("p_year"); call.addNamedArgument("p_rel"); call.useNamedCursorOutputAsResultSet("p_resset"); resset是我作为Cursor的结果 – 正如你所看到的 – 当程序看起来像这样工作没有任何问题: create or replace PROCEDURE TEST (p_year IN NUMBER,p_rel IN VARCHAR2,p_resset OUT SYS_REFCURSOR) AS BEGIN OPEN p_resset FOR SELECT NVL (s.KA,'Summe') ka,COUNT (s.AZ) az FROM table1 s,table2 w WHERE s.year= w.year AND w.relevant = p_rel AND s.year = p_year END; 现在我添加了一个名为“p_data”的输出参数,并带有一个自己的select调用 create or replace PROCEDURE TEST (p_year IN NUMBER,p_data OUT VARCHAR2,p_resset OUT SYS_REFCURSOR) AS BEGIN SELECT month INTO p_data FROM month_table b WHERE month_nr = (SELECT MAX (month) FROM instruction WHERE year= b.year) AND year= p_year; OPEN p_resset FOR SELECT NVL (s.KA,table2 w WHERE s.year= w.year AND w.relevant = p_rel AND s.year = p_year END; 这就是我被卡住的地方. 我不知道如何调用单个字符串,这是我尝试添加的新select语句(月)的结果 "call.addNamedOutputArgument("p_data");" 但那是完全错误的. 也许我也很高兴知道我是如何处理从第一次调用中得到的结果: DataReadQuery query = new DataReadQuery(); query.setCall(call); query.addArgument("p_year"); query.addArgument("p_rel"); @SuppressWarnings("rawtypes") List args = new ArrayList(); args.add(dbyear); args.add(relevation); @SuppressWarnings("rawtypes") List result= (List) s.executeQuery(query,args); for (int i = 0; i < ergebnis.size(); i++){ testDto record = new testDto(); ArrayRecord ar=(ArrayRecord) ergebnis.get(i); record.setKa((ar.get("ka")).toString()); record.setAz((ar.get("az")).toString()); System.out.println("cursor : " + ergebnis.get(i)); result.add(ergebnis); } 但正如我所说,我无法处理单个字符串,无法将其作为参数创建一个html / excel文件,这是我必须处理的问题. 解决方法
我觉得你很亲密你需要从结果集中获取值
尝试类似的东西 StoredProcedureCall call = new StoredProcedureCall(); call.setProcedureName("test"); call.addNamedArgument("p_year"); call.addNamedArgument("p_rel"); call.addNamedOutputArgument("p_data"); call.useNamedCursorOutputAsResultSet("p_resset"); @SuppressWarnings("rawtypes") List result= (List) s.executeQuery(query,args); DatabaseRecord record = (DatabaseRecord)results.get(0); String data = (String) record.get("p_data"); 看看这些片段 http://www.ctmmc.net/how-to-call-stored-procedures http://blog.yenlo.com/nl/calling-oracle-stored-procedures-from-eclipselink-with-multiple-out-parameters (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |