gpt4 book ai didi

java - StoredProcedureCall 1x Varchar 输出 1x Cursor 输出

转载 作者:太空狗 更新时间:2023-10-29 13:53:28 24 4
gpt4 key购买 nike

我的问题可能有点令人困惑。我遇到的问题是我正在使用来自 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" 的输出参数,带有自己的选择调用

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;

这就是我卡住的地方。

我不知道如何调用一个字符串,它是我尝试添加的新选择语句(月份)的结果

"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

关于java - StoredProcedureCall 1x Varchar 输出 1x Cursor 输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31853451/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com