有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

java StoredProcedureCall 1x Varchar输出1x游标输出

我的问题可能有点困惑。我有一个问题,我正在用Java中的StoredProcedureCall调用一个过程,例如:

StoredProcedureCall call = new StoredProcedureCall();
    call.setProcedureName("test");
    call.addNamedArgument("p_year");
    call.addNamedArgument("p_rel");
    call.useNamedCursorOutputAsResultSet("p_resset");

resset是我作为光标的结果-正如您所看到的-当过程看起来像:

 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_rel IN VARCHAR2,
                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, '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;

这就是我被卡住的地方

我不知道如何调用一个字符串,它是我试图添加的新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文件,这就是我必须处理的问题


共 (2) 个答案

  1. # 1 楼答案

    我觉得你们很接近。您需要从resultset中获取值

    试试这样

    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

  2. # 2 楼答案

    “Select Into”查询在新表p_data中插入了“month”字段。”选择“进入”将不会返回数据。 您需要编写单独的select查询以从表p_数据中获取数据: 一旦在存储过程中完成了这样的编写。 试着按照上面提到的方式调用程序

    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");
    

    希望这对你有用