on 2020 Jul 14 2:53 PM
Starting from Breck's article here: Building a Link-Checker Inside SQL
I created (copied) a basic procedure to check the HTTP status of a webpage:
CREATE OR REPLACE PROCEDURE sxhttp_head_attributes ( IN url LONG VARCHAR ) RESULT ( attribute LONG VARCHAR, value LONG VARCHAR ) URL '!url' TYPE 'HTTP:HEAD';
I need to take different actions based on different response codes or an errors of that page, so I want to select the results of the procedure:
select * from sxhttp_head_attributes ('http://www.google.com');
This gives results in 12.0.1.3592.
In 17.0.6.2757 it errors out:
There was an error reading the results of the SQL statement. The displayed results may be incorrect or incomplete. sxhttp_head_attributes returned a result set with a different schema than expected SQLCODE=-866, ODBC 3 State="HY000" Line 1, column 1
However calling the procedure instead of selecting from it works on both versions
call sxhttp_head_attributes ('http://www.google.com');
The trouble is I am not familiar with a way to use the call syntax of a procedure and take actions based on the results, as I would usually select from the procedure to evaluate the results.
So the question is why is there a difference in behavior and is it intended. The goal is to provide a way to support something like this (crude example) that will work on both versions:
BEGIN DECLARE STAT LONG VARCHAR; SELECT Value into STAT from sxhttp_head_attributes ('http://www.google.com') where Attribute = 'Status'; select CASE WHEN STAT like '%200%' THEN 'Server Up' WHEN STAT like '%500%' THEN 'Server Error' ELSE 'Server Down' END CASE as EasyStatus; END
Is it possible the web client procedure really has a different schema with v17.0.9? IIRC there has been an additional column...
To quote the docs:
If you are using database created with version 17.0.1 or higher, then the result set contains a third column named Instance, of type INTEGER.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
Sure enough! There is a third column with integer codes (1s and 2s on the result for http://www.google.com).
RESULT clause
The RESULT clause is required to use the procedure in a SELECT statement. The RESULT clause must return two columns. The first column contains HTTP response header, status, and response body attributes, while the second column contains the values for these attributes. The RESULT clause must specify two character data types. For example, VARCHAR or LONG VARCHAR. If the RESULT clause is not specified, the default column names are Attribute and Value and their data types are LONG VARCHAR. If you are using database created with version 17.0.1 or higher, then the result set contains a third column named Instance, of type INTEGER. If the result of calling the HTTP request returns more than one attribute with the same name, then the Instance value can be used to obtain the different attribute values.
Well, at least the newer What's New sections for 17.0.6 and above... 🙂
FWIW, that enhancement is also contained in the DCX docs as a comment.
User | Count |
---|---|
71 | |
10 | |
8 | |
7 | |
7 | |
6 | |
6 | |
6 | |
6 | |
5 |
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.