Java StoredProcedureCall 1x Varchar输出1x游标输出
我的问题可能有点困惑。我遇到的问题是,我正在使用StoredProcedureCall从Java调用一个过程,例如:Java StoredProcedureCall 1x Varchar输出1x游标输出,java,html,sql,oracle,java-stored-procedures,Java,Html,Sql,Oracle,Java Stored Procedures,我的问题可能有点困惑。我遇到的问题是,我正在使用StoredProcedureCall从Java调用一个过程,例如: StoredProcedureCall call = new StoredProcedureCall(); call.setProcedureName("test"); call.addNamedArgument("p_year"); call.addNamedArgument("p_rel"); call.useNamedCursorOutput
StoredProcedureCall call = new StoredProcedureCall();
call.setProcedureName("test");
call.addNamedArgument("p_year");
call.addNamedArgument("p_rel");
call.useNamedCursorOutputAsResultSet("p_resset");
RESET是我作为光标的结果-正如您所看到的-当过程看起来像:
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文件,这就是我必须处理的问题 我想你很接近了。您需要从结果集获取值 试试像这样的东西
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");
查看这些代码片段
“Select Into”查询已将“月”字段插入到新表p_数据中。”选择“进入”将不返回数据。 您需要编写单独的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");
希望这对您有用不懂Java所以不发布答案,不过有一些想法:您的“Select Into”查询已将“month”字段放入一个名为p_data的新表中;'选择“进入”不会创建结果集/返回和数据,仅执行此操作。要从P_数据中检索数据,需要一个单独的select语句select MOUNT from P_数据。您还说过P_数据是一个varchar2数据类型,而实际上它是一个表。。所以我认为这是不对的。可以帮助