java – StoredProcedureCall 1x Varchar输出1x光标输出

前端之家收集整理的这篇文章主要介绍了java – StoredProcedureCall 1x Varchar输出1x光标输出前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我的问题可能有点令人困惑.我有一个问题,我正在用 Java调用StoredProcedureCall的过程,例如:
  1. StoredProcedureCall call = new StoredProcedureCall();
  2. call.setProcedureName("test");
  3. call.addNamedArgument("p_year");
  4. call.addNamedArgument("p_rel");
  5. call.useNamedCursorOutputAsResultSet("p_resset");

resset是我作为Cursor的结果 – 正如你所看到的 – 当程序看起来像这样工作没有任何问题:

  1. create or replace PROCEDURE TEST (p_year IN NUMBER,p_rel IN VARCHAR2,p_resset OUT SYS_REFCURSOR) AS
  2. BEGIN
  3. OPEN p_resset FOR
  4. SELECT NVL (s.KA,'Summe') ka,COUNT (s.AZ) az
  5. FROM table1 s,table2 w
  6. WHERE s.year= w.year
  7. AND w.relevant = p_rel
  8. AND s.year = p_year
  9. END;

现在我添加了一个名为“p_data”的输出参数,并带有一个自己的select调用

  1. create or replace PROCEDURE TEST (p_year IN NUMBER,p_data OUT VARCHAR2,p_resset OUT SYS_REFCURSOR) AS
  2. BEGIN
  3. SELECT month
  4. INTO p_data
  5. FROM month_table b
  6. WHERE month_nr = (SELECT MAX (month)
  7. FROM instruction
  8. WHERE year= b.year)
  9. AND year= p_year;
  10.  
  11. OPEN p_resset FOR
  12. SELECT NVL (s.KA,table2 w
  13. WHERE s.year= w.year
  14. AND w.relevant = p_rel
  15. AND s.year = p_year
  16. END;

这就是我被卡住的地方.

我不知道如何调用单个字符串,这是我尝试添加的新select语句(月)的结果

  1. "call.addNamedOutputArgument("p_data");"

但那是完全错误的.

也许我也很高兴知道我是如何处理从第一次调用中得到的结果:

  1. DataReadQuery query = new DataReadQuery();
  2. query.setCall(call);
  3. query.addArgument("p_year");
  4. query.addArgument("p_rel");
  5.  
  6.  
  7. @SuppressWarnings("rawtypes")
  8. List args = new ArrayList();
  9. args.add(dbyear);
  10. args.add(relevation);
  11.  
  12. @SuppressWarnings("rawtypes")
  13. List result= (List) s.executeQuery(query,args);
  14.  
  15. for (int i = 0; i < ergebnis.size(); i++){
  16. testDto record = new testDto();
  17. ArrayRecord ar=(ArrayRecord) ergebnis.get(i);
  18.  
  19. record.setKa((ar.get("ka")).toString());
  20. record.setAz((ar.get("az")).toString());
  21.  
  22. System.out.println("cursor : " + ergebnis.get(i));
  23.  
  24. result.add(ergebnis);
  25. }

但正如我所说,我无法处理单个字符串,无法将其作为参数创建一个html / excel文件,这是我必须处理的问题.

解决方法

我觉得你很亲密你需要从结果集中获取

尝试类似的东西

  1. StoredProcedureCall call = new StoredProcedureCall();
  2. call.setProcedureName("test");
  3. call.addNamedArgument("p_year");
  4. call.addNamedArgument("p_rel");
  5. call.addNamedOutputArgument("p_data");
  6. call.useNamedCursorOutputAsResultSet("p_resset");
  7.  
  8.  
  9. @SuppressWarnings("rawtypes")
  10. List result= (List) s.executeQuery(query,args);
  11. DatabaseRecord record = (DatabaseRecord)results.get(0);
  12. 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

猜你在找的Java相关文章