*************************************************************** * * COMMENT SECTION * * DATE 1989/11/09 EMBEDDED COBOL LANGUAGE * NIST SQL VALIDATION TEST SUITE V6.0 * DISCLAIMER: * This program was written by employees of NIST to test SQL * implementations for conformance to the SQL standards. * NIST assumes no responsibility for any party's use of * this program. * * COB009.PCO * WRITTEN BY: S Hurwitz * * THIS PROGRAM TESTS SQL INTERSPERSED WITH * COBOL NESTED IF STATEMENTS, ON SIZE ERROR, * NOT ON SIZE ERROR, LABEL ON SAME LINE WITH EXEC SQL, * AND VALUE IS CLAUSE * * REFERENCES * AMERICAN NATIONAL STANDARD database language - SQL * X3.168-1989 * * 9.5 <embedded SQL COBOL program> * * ***************************************************************
MOVE"HU"TO uid CALL"AUTHID"USING uid MOVE"not logged in, not"TO uidx EXECSQLSELECT
USER INTO :uidx FROM HU.ECCO END-EXEC if (uid NOT = uidx) then DISPLAY"ERROR: User " uid " expected." DISPLAY"User " uidx " connected." DISPLAY" " STOPRUN END-IF
MOVE 0 TO errcnt DISPLAY "SQL Test Suite, V6.0, Embedded COBOL, cob009.pco" DISPLAY" " DISPLAY "59-byte ID" DISPLAY"TEd Version #" DISPLAY" " * date_time print * ACCEPT TO-DAY FROMDATE ACCEPT THE-TIME FROMTIME DISPLAY"Date run YYMMDD: " TO-DAY " at hhmmssff: " THE-TIME
******************** BEGIN TEST0292 *******************
EXECSQLDELETEFROM EE END-EXEC EXECSQLDELETEFROM TEMP_S END-EXEC EXECSQLINSERTINTO TEMP_S
VALUES ('SMH',-55,'NA') END-EXEC EXECSQLINSERTINTO EE
VALUES (:V2) END-EXEC EXECSQLSELECT INTTEST INTO :INTTST1 FROM EE
WHERE INTTEST = 5 END-EXEC EXECSQLSELECT EMPNUM INTO :EMPNO1 FROM TEMP_S
WHERE EMPNUM = :V1 END-EXEC DISPLAY" EMPNO1 should be SMH and INTTST1 = 5 "
EXECSQLDELETEFROM FF END-EXEC EXECSQLDELETEFROM EE END-EXEC EXECSQLINSERTINTO EE VALUES (1) END-EXEC
MOVE 0 TO I1 MOVE 0 TO J2 MOVE 0 TO I3 MOVE 0 TO I4 MOVE 0 TO J5
IF I1 = 0 IF J2 = 0 IF I3 = 0 EXECSQLSELECT HOURS INTO :HOURS1 FROM WORKS
WHERE EMPNUM = 'E3'END-EXEC
.
DIVIDE I1 INTO HOURS1 GIVING I4 ONSIZEERROR EXECSQLINSERTINTO FF
VALUES (9) END-EXEC. IF ( X = "X" ) GOTO P110. DISPLAY" This should not be displayed! ".
P110. EXECSQLSELECT INTTEST INTO :J5 FROM FF END-EXEC ADD J5 TO J2 GIVING J2 NOTONSIZEERROR EXECSQLDELETEFROM EE END-EXEC EXECSQLINSERTINTO EE
VALUES (4) END-EXEC END-ADD EXECSQLSELECT INTTEST INTO :J6 FROM EE END-EXEC
DISPLAY" The correct answer is: J5 = 9, J2 = 9, J6 = 4 " DISPLAY" and HOURS1 = 20 " DISPLAY" Your answer is: J5 = " J5 DISPLAY" J2 = " J2 DISPLAY" J6 = " J6 DISPLAY" HOURS1 = " HOURS1 IF ( X = "X" ) GOTO P100. DISPLAY" SURPRISE! THIS STATEMENT SHOULD NOT EXECUTE ".
P100. EXECSQL ROLLBACK WORK END-EXEC
if ( J5 = 9 and J2 = 9 and J6 = 4 and HOURS1 = 20) then
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.