|
My orginal question was Data Ques/MQ Series vs Stored Procedures not HLL vs SQL Yes I use HLL for stored procedures thats why they are so fast, To me data que is good for passing only one limited message. But not for large amount of data. How do you bring 1000 records back to your java program? I hope you don't loop your code to do that or try to retrieve an unlimitted amount of data using one parameter :-) (You have to call AS/400 1000 times). Comparing to one call using Stored Procedure. (performance). If you do how do you parse the retrieved data from data que? 2200 bytes? Just wondering whats in it. Stored procedure returns you the data in much simpler and better way. Building one SQL statement for result set is much more cleaner and easy to maintain comparing to data structure and reading data in a loop, parsing data and, going back and forth to AS/400 to read more data. Just wondering why you mentioned bidrectional. Sored Procedure are not bidirectional?. Actually they are much better you know what you are sending and what you are receiving? Error Trapping. There is no solution for poor programming. You already mentioned it :-) Just put a MONMSG CPF0000 in HLL just like you did in java? Sorry I ment to say that you have to wait an see Data Que? Which is kinda error trapping for me. Again I am trying to see a difference b/w Data Ques, MQSeries and Stored Procedures. Not HLL or SQL Just want to mention, you are doing a great job out there. (Are you getting paid for this :-) just kidding) Thanks Mohammad Tanveer -----Original Message----- From: Joe Pluta [mailto:joepluta@PlutaBrothers.com] Sent: Thursday, August 30, 2001 2:21 PM To: java400-l@midrange.com Subject: RE: Communicating between java & rpg? Simpler? How? parms[0].setInputData(data); if (call.run() == false) { throw new Exception("Receive failed."); } else { data = parms[0].getOutputData(); } This is as simple as you can get, and it's bidirectional. It passes data to and from the program. And evidently you misread the code, because it doesn't pass 2200 parameters, it passes a single parameter of 2200 bytes. No need for error trapping? Are your stored procedures calling HLL programs or executing SQL statements? For the former, what do you do if your program name is wrong, or your program ends in error? For the latter, what happens if the SQL statement fails? How do you catch those conditions? In my case I could ignore the errors, but that's a pretty poor programming practice. Performance? Performance of native I/O is often much better than SQL, especially when writing data - I recently posted the results of a test that shows that updating data with an RPG program is five times faster than using embedded SQL. From what I understand, the JDBC driver is even slower. If, on the other hand, you're calling an RPG program that does native I/O, you have to parse the SQL statement and, for inquiries, build a result set in your program. I don't have to do that in mine. No, native I/O is simpler, faster and more flexible than SQL. Joe > -----Original Message----- > From: Tanveer, Mohammad > > Thanks, I think stored procedures are much simpler than this. > No need for > error trapping and waiting for data (performance), debugging is much > simpler, I am not sure why people want to pass 2200 parameters. May be a > old design concept. Anyways at least I know how to call an AS/400 program > and pass parameters. Thanks a lot. _______________________________________________ This is the Java Programming on and around the iSeries / AS400 (JAVA400-L) mailing list To post a message email: JAVA400-L@midrange.com To subscribe, unsubscribe, or change list options, visit: http://lists.midrange.com/cgi-bin/listinfo/java400-l or email: JAVA400-L-request@midrange.com Before posting, please take a moment to review the archives at http://archive.midrange.com/java400-l.
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.