- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我的问题可能有点令人困惑。我遇到的问题是我正在使用来自 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
BẮT ĐẦU
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
KẾT THÚC;
现在我添加了一个名为 "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
BẮT ĐẦU
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
KẾT THÚC;
这就是我卡住的地方。
我不知道如何调用一个字符串,它是我尝试添加的新选择语句(月份)的结果
"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 文件,这就是我必须处理的问题。
câu trả lời hay nhất
我觉得你很接近。您需要从结果集中获取值
尝试类似的东西
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
关于java - StoredProcedureCall 1x Varchar 输出 1x Cursor 输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31853451/
Tôi đang viết một phương thức Java có chữ ký sau. void Logger(Phương thức phương thức, Object[] args); Nếu một phương thức (chẳng hạn như ABC() ) gọi phương thức này Logger, thì nó sẽ
Tôi mới làm quen với Java. Vấn đề của tôi là chương trình Java của tôi không thể tìm thấy JButton mà tôi đang cố sử dụng làm tệp hình ảnh. (Hiện tại mã này không làm gì cả vì tôi chỉ có được giao diện mong muốn trước tiên). Đây là mã lớp chính của tôi: packag
Được rồi, hôm nay tôi sẽ thực hiện một cuộc phỏng vấn và tôi đã viết mã Java được nhiều năm. Trong cuộc phỏng vấn, anh ấy nói "Việc thu gom rác Java là một vấn đề hóc búa và tôi có một số người bạn đang cố gắng tìm ra nó. Bạn thấy thế nào về vấn đề này?". Cô ấy đang cố nói dối tôi phải không? Hoặc cả cuộc đời tôi
Bạn tôi đưa cho tôi một câu đố để giải. Nó diễn ra như thế này: Có 100 người trong số họ, đến lượt mình, thực hiện như sau.
Nếu tôi biên dịch một ứng dụng sử dụng mã Java 5 thành mã byte, liệu tệp .class kết quả có chạy trong Java 1.4 không? Nếu cái sau hoạt động và tôi đang cố gắng sử dụng Jav trong ứng dụng Java 1.4 của mình
Có những câu hỏi về lý do tại sao Java không hỗ trợ các kiểu không dấu và một số câu hỏi về việc xử lý các kiểu không dấu. Tôi đã thực hiện một số tìm kiếm và có vẻ như Scala cũng không hỗ trợ các kiểu dữ liệu không dấu. Hạn chế là Java và S
Tôi chỉ muốn biết liệu mã byte được tạo trong một phiên bản java có chạy trên các phiên bản java khác Câu trả lời hay nhất Thông thường, mã byte có thể chạy trên các phiên bản java mới hơn mà không cần sửa đổi. Nó sẽ không chạy trên các phiên bản cũ hơn trừ khi bạn sử dụng các tham số đặc biệt (
Tôi có một câu hỏi cơ bản về việc thực thi các chương trình java trong dấu nhắc lệnh. Trên một số máy chúng ta cần chỉ định -cp. (đường dẫn lớp) thực thi chương trình java cùng lúc (test là tên file java và file .class tồn tại trong cùng thư mục) jav
Tôi đã đọc StackOverflow được một thời gian và tôi mới có đủ can đảm để đặt câu hỏi. Tôi 20 tuổi và hiện đang học tại một trường đại học CNTT ở quê hương (Cluj-Napoca, Romania). Giới thiệu thế đủ rồi :D Về cơ bản, tôi có một công ty cung cấp ứng dụng kế toán
Tôi không thể public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
Tôi đã triển khai một ngôn ngữ thông dịch đơn giản với kiểu gõ động trong Java. Thật không may tôi gặp phải vấn đề sau. Đoạn mã sau được sử dụng trong quá trình thử nghiệm: def main() { def ks = Map[[1, 2]].keySet()
Luôn nhắc nhập một số từ 1 đến 10 - kết quả sẽ cộng thêm st, rd, th và nd vào số đó. Viết chương trình nhắc người dùng nhập bất kỳ số nguyên nào từ 1 đến 10, sau đó hiển thị số nguyên đó ở dạng thứ tự có thêm hậu tố. công cộng
Tôi có DownloadFile.java này và nó tải xuống tệp như mong đợi: import java.io.*; import java.net.URL public class DownloadFile {
Tôi muốn thêm độ trễ vào GUI. Tôi đặt 2 vòng lặp for rồi vẽ lại nhãn, nhưng 2 vòng lặp for này được thực thi lần lượt và nhãn được vẽ lại đến nhãn cuối cùng. Tôi có thể làm gì? for(int i=0;
Tôi đang thực hiện một số thử nghiệm với các mục danh sách của đối tượng Sinh viên, nhưng tôi thích tạo một danh sách được mã hóa cứng trong đối tượng lớp java rồi lấy dữ liệu từ đó thay vì kết nối với cơ sở dữ liệu và chọn các bản ghi trong tập kết quả. Tuy nhiên, đã lâu rồi tôi mới làm việc này,
Tôi biết rằng việc tạo đối tượng được chia thành ba phần: khai báo khởi tạo khởi tạo classA{} classB mở rộng classA{} classA obj = khởi tạo classB mới (1,1);
Tôi quan tâm đến việc xây dựng hệ thống theo dõi xe bằng GPRS. Tuy nhiên, tôi có một số câu hỏi dành cho những ai đã từng làm việc này trước đây: GPRS có phải là công nghệ tốt nhất không? Mọi người có nhận thức được vấn đề gì không? Tôi dự định sử dụng Java/Java EE - có công nghệ nào tốt hơn không? nếu như
Tôi có thể đảo ngược mảng bằng phương pháp đệ quy như: array={1,2,3,4,5} array result={5,4,3,2,1} nhưng kết quả của tôi là cùng một mảng và tôi không biết Tại sao, xin hãy giúp tôi. lớp công khai Đệ quy { p
Có một cách tiêu chuẩn để làm điều này? Bao gồm mã nguồn Java - Mã kiểm tra - Đơn vị liên kết Ant hoặc Maven Tích hợp liên tục (có thể là kiểm soát hành trình) Công cụ kiểm soát phiên bản ClearCase Triển khai đến máy chủ ứng dụng Cuối cùng, tôi muốn có một môi trường tích hợp và xây dựng tự động.
Tôi thậm chí không biết liệu điều này có khả thi hay không và tôi rất nghi ngờ điều đó là có thể, nhưng nếu có, bạn có thể cho tôi biết cách thực hiện không? Tôi chỉ muốn biết cách in một số văn bản từ máy in. Có ý tưởng gì không? Câu trả lời hay nhất Đây là một cái gì đó đơn giản hơn. nhập javax.swin
Tôi là một lập trình viên xuất sắc, rất giỏi!