我的问题可能有点令人困惑.我有一个问题,我正在用
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");
看看这些片段