|
Quello che segue e' il metodo comune per gestire i parametr sulle query standard, quello in allegato e' tramite la definizione via QMQRY usando pero' dei source. Spero che ti possa aiutare. Marco Facchinetti --- Peter Vidal <Peter_Vidal@xxxxxxxx> wrote: > First, you need to define your Query/400. On the SELECT > RECORDS Screen, > you need to use a colon (:) to qualify the fields as > follows: > > Select Records > Type comparisons, press Enter. Specify OR to start > each new group. > Tests: EQ, NE, LE, GE, LT, GT, RANGE, LIST, LIKE, IS, > ISNOT... > > AND/OR Field Test Value (Field, Number, > 'Characters', or > ...) > DATE1 EQ :USERDATE1 > AND DATE2 EQ :USERDATE2 > > > A second screen will pop-up: (You can specify any file > in use by the > query) > > Specify Dependent Value Qualifiers > > Type choices, press Enter. > > Qualifier type . . . . 2 1=Query, 2=File > > > Query or file . . . . UNCFORDS Name, F4 for > list of files > Library . . . . . . PRODLIB Name, *LIBL, F4 > for list > > For choice 2=File: > File member . . . . *FIRST Name, *FIRST, > F4 for list > > Second, on a CL, use STRQMQRY command to run the query as > follows: > > STRQMQRY > QMQRY(Library_Name/QRYDFN_Name) ALWQRYDFN(*YES) > SETVAR((DATE1 &SCRDATE1) (DATE2 &SCRDATE2)) > > NOTE: Work fields must be type *CHAR, no matter > that the field is a number > on the query. > > > Hope this helps, > > Peter Vidal > PALL Aeropower Corporation > SR Programmer Analyst > 5775 Rio Vista Drive > Clearwater, FL 33760-3137 > (727)539-8448 > www.pall.com > > "My religion consists of a humble admiration of the > illimitable superior > spirit who reveals himself in the slight details we are > able to perceive > with our frail and feeble mind." > Albert Einstein > > -- > This is the Midrange Systems Technical Discussion > (MIDRANGE-L) mailing list > To post a message email: MIDRANGE-L@xxxxxxxxxxxx > To subscribe, unsubscribe, or change list options, > visit: > http://lists.midrange.com/mailman/listinfo/midrange-l > or email: MIDRANGE-L-request@xxxxxxxxxxxx > Before posting, please take a moment to review the > archives > at http://archive.midrange.com/midrange-l. > > __________________________________ Do you Yahoo!? Yahoo! Mail - 50x more storage than other providers! http://promotions.yahoo.com/new_mail
Questo è il source di una definizione un pochino più complessa delle altre: Colonne . . . : 1 79 Esame METAILEO/SQL SEU==> CABCOMTIF FMT ** ...+... 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+... 7 ...+... ****************** Inizio dati ****************************************************************************************** 0001.00 select tacodice , tadscabina, tpdescri40, ticodice, tidstipute, 020711 0002.00 count(ascdutente) 020711 0003.00 from tabcab0f, dbsto01l, dbana01l, tabpae0f, tabcom0f, tabtip0f, tabtif0f 020711 0004.00 where abstatorec = ' ' and 011206 0005.00 (abdtfinero is null or abdtfinero > &DATAA ) and 011206 0006.00 (abdtiniero is not null and abdtiniero <= &DATAA ) 011213 0007.00 and tlcdtiputf = ticodice 020711 0008.00 and ascdtiputi = tlcodice 020711 0009.00 and tfcdcomune = tpcodice 020711 0010.00 and abcdpaese = tfcodice 020711 0011.00 and ascdutente = abcdutente 020711 0012.00 and asseqstori = abprcondiz 020711 0013.00 and tacodice = ascdcabina 020711 0014.00 group by tadscabina, tacodice, tpdescri40, ticodice, tidstipute 020711 0015.00 order by tadscabina, tacodice, tpdescri40, ticodice, tidstipute 020711 ******************** Fine dati ****************************************************************************************** Tutta la parte dove vedi (X)SQLFORM è relativo alla formattazione in stampa!! e il CL che lo esegue: XSQLPARM: PGM PARM(&DATA &MEMBRO &STAMPA &LARG) /* Crea ed + esegue un statement SQL memorizzato nel + membro richiesto del file SQL della + libreria METAILEO, passa un parametro. */ DCL VAR(&D1) TYPE(*CHAR) LEN(8) DCL VAR(&D2) TYPE(*CHAR) LEN(10) DCL VAR(&DATA) TYPE(*CHAR) LEN(10) DCL VAR(&MEMBRO) TYPE(*CHAR) LEN(10) DCL VAR(&STAMPA) TYPE(*CHAR) LEN(1) DCL VAR(&LARG ) TYPE(*CHAR) LEN(1) DCL VAR(&STRINGA) TYPE(*CHAR) LEN(100) DCL VAR(&FORM) TYPE(*CHAR) LEN(10) VALUE('*SYSDFT') CVTDAT DATE(&DATA) TOVAR(&D1) FROMFMT(*EUR) CHGVAR VAR(&D2) VALUE('''' *TCAT &D1 *TCAT '''') CHGVAR VAR(&STRINGA) VALUE(&DATA) /* crea il query da eseguire */ DLTQMQRY QMQRY(METAILEO/XSQL) MONMSG MSGID(CPF0000) DLTQMFORM QMFORM(METAILEO/XSQLFORM) MONMSG MSGID(CPF0000) CRTQMQRY QMQRY(METAILEO/XSQL) SRCFILE(METAILEO/SQL) + SRCMBR(&MEMBRO) AUT(*ALL) /* se presente abbina form */ RTVMBRD FILE(METAILEO/SQLFORM) MBR(&MEMBRO) MONMSG MSGID(CPF9815) EXEC(GOTO CMDLBL(NOFORM)) DLTQMFORM QMFORM(METAILEO/XSQLFORM) MONMSG MSGID(CPF0000) /* Si lavora sempre su un membro di lavoro */ CPYF FROMFILE(SQLFORM) TOFILE(SQLFORM) + FROMMBR(&MEMBRO) TOMBR(XSQLFORM) + MBROPT(*REPLACE) /* imposta la data nel titolo della stampa */ OVRDBF FILE(SQLFORM) MBR(XSQLFORM) CALL PGM(CL01) PARM(&STRINGA) DLTOVR FILE(SQLFORM) MONMSG MSGID(CPF0000) CRTQMFORM QMFORM(METAILEO/XSQLFORM) + SRCFILE(METAILEO/SQLFORM) + SRCMBR(XSQLFORM) AUT(*ALL) CHGVAR VAR(&FORM) VALUE('XSQLFORM') NOFORM: IF COND(&STAMPA *NE 'S') THEN(STRQMQRY + QMQRY(METAILEO/XSQL) QMFORM(&FORM) + SETVAR((DATAA &D2))) ELSE CMD(DO) IF COND(&LARG *EQ ' ') THEN(OVRPRTF + FILE(QPQXPRTF) PAGESIZE(*N 132) + OVRSCOPE(*JOB)) ELSE CMD(OVRPRTF FILE(QPQXPRTF) PAGESIZE(*N 198) + CPI(15) OVRSCOPE(*JOB)) STRQMQRY QMQRY(METAILEO/XSQL) OUTPUT(*PRINT) + QMFORM(&FORM) SETVAR((DATAA &D2)) DLTOVR FILE(QPQXPRTF) MONMSG MSGID(CPF0000) ENDDO DLTQMQRY QMQRY(METAILEO/XSQL) MONMSG MSGID(CPF0000) DLTQMFORM QMFORM(METAILEO/XSQLFORM) MONMSG MSGID(CPF0000) DLTOVR FILE(QPQXPRTF) LVL(*JOB) MONMSG MSGID(CPF0000) ENDPGM La parte che segue è totalmente facoltativa ed è relativa ai FORM (formattazione per stampa): H QM4 05 F 01 E V W E R 01 03 02/02/26 18:29 * * V 1001 = Descrizione query. V 1001 050 Utenze attive alla data per cabina/comune/tip.ut * * T 1110 = Tabella colonne. * 006 = Numero di record R presenti * 005 = Numero di coppie di definizioni: * - La prima indica il tipo di definizione * - La seconda la lunghezza nel record R * 1112 = Tipo dati: CHAR NUMERIC * 1113 = Intestazioni colonne * 1114 = Utilizzo: BREAKn SUM MIN MAX AVG.... * 1115 = Spazio tra colonne (default 2) * 1116 = Larghezza colonna * 1117 = Editazione * 1118 = Sequenza T 1110 006 005 1114 010 1116 006 1118 003 1115 003 1113 060 * Utilizzo.. Lenght Seq Spc Intestazione colonne.................................... R BREAK1 6 1 Codice_cabina R BREAK1 20 2 1 Descrizione Cabina R BREAK2 20 3 1 Descrizione Comune R 2 4 1 Cd_Tp_Fi R 20 5 1 Tipologia Fiscale R SUM 18 6 1 Numero_Utenti_Attivi * * T 1210 = Tabella intestazione report. * 003 = Numero di record R presenti * 003 = Numero di coppie di definizioni: * - La prima indica il tipo di definizione * - La seconda la lunghezza nel record R * 1212 = Numero riga intestazione * 1213 = Allineamento (LEFT CENTER RIGHT) * 1214 = Testo. T 1210 003 003 1212 004 1213 006 1214 055 * Prog Allin. Testo intestazione (& è dove verrà messa la data) R 1 CENTER ******************************************************* R 2 CENTER * Utenti attivi x Cabina/Comune/Utenza al & * R 3 CENTER ******************************************************* * Campi V sintassi: V 1201 001 0 (1201=Funzione 001=Len valore 0=Valore) * Numero di linee blank prima dell'intestazione V 1201 001 0 * Numero di linee blank dopo l'intestazione V 1202 001 2 * Numero di linee blank prima del testo fondo pagina V 1301 001 2 * Numero di linee blank dopo il testo fondo pagina V 1302 001 0 * Stampare testo fine stampa su nuova pagina. V 1401 002 NO * Mettere testo fine stampa a linea ?? V 1402 004 2 * Linee da saltare prima dell stampa del testo finale. V 1403 006 0 * * T 1410 = Tabella testo finale stampa * 001 = Numero di record R presenti * 003 = Numero di coppie di definizioni: * - La prima indica il tipo di definizione * - La seconda la lunghezza nel record R * 1412 = Numero riga testo fine stampa * 1413 = Allineamento (LEFT CENTER RIGHT) * 1414 = Testo. T 1410 001 003 1412 004 1413 006 1414 055 R 1 RIGHT Totale finale ************************************************* * OPTIONS * ************************************************* * 1501 Detail line spacing 1 * 1502 Outlining for break columns YES * 1503 Default break text YES * 1505 Column wrapped lines kept on page YES * 1507 Column heading separators YES * 1508 Break summary separators YES * 1510 Final summary separators YES V 1501 001 1 V 1502 003 YES V 1503 003 YES V 1505 003 YES V 1507 003 YES V 1508 003 YES V 1510 003 YES ************************************************* * BREAK 1 ************************************************* * Break level indicator - V 3080 001 1 * New page for break heading NO V 3101 002 NO * Repeat column headings NO V 3102 002 NO * Blank lines before heading 0 V 3103 001 0 * Blank lines after heading 0 V 3104 001 0 * T 3110 = Break heading table 0-5 * 001 = Numero di record R presenti * 003 = Numero di coppie di definizioni: * - La prima indica il tipo di definizione * - La seconda la lunghezza nel record R * 3112 = Numero riga testo break * 3113 = Allineamento (LEFT CENTER RIGHT) * 3114 = Testo. ***** T 3110 001 003 3112 001 3113 007 3114 050 ***** R 1 RIGHT Totale cabina * New page for break footing NO V 3201 002 NO * Put break summary at line 1 V 3202 004 1 * Blank lines before footing 0 V 3203 006 0 * Blank lines after footing 1 V 3204 001 1 * * T 3210 = Break footing table 0-5 * 001 = Numero di record R presenti * 003 = Numero di coppie di definizioni: * - La prima indica il tipo di definizione * - La seconda la lunghezza nel record R * 3212 = Numero riga testo break * 3213 = Allineamento (LEFT CENTER RIGHT) * 3214 = Testo. T 3210 001 003 3212 001 3213 007 3214 050 R 1 RIGHT Totale cabina di &2 ************************************************* * BREAK 2 ************************************************* * Break level indicator - V 3080 001 2 * New page for break heading NO V 3101 002 NO * Repeat column headings NO V 3102 002 NO * Blank lines before heading 0 V 3103 001 0 * Blank lines after heading 0 V 3104 001 0 * T 3110 = Break heading table 0-5 * 001 = Numero di record R presenti * 003 = Numero di coppie di definizioni: * - La prima indica il tipo di definizione * - La seconda la lunghezza nel record R * 3112 = Numero riga testo break * 3113 = Allineamento (LEFT CENTER RIGHT) * 3114 = Testo. **** T 3110 001 003 3112 001 3113 007 3114 050 **** R 1 RIGHT Totale comune * New page for break footing NO V 3201 002 NO * Put break summary at line 1 V 3202 004 1 * Blank lines before footing 0 V 3203 006 0 * Blank lines after footing 1 V 3204 001 1 * * T 3210 = Break footing table 0-5 * 001 = Numero di record R presenti * 003 = Numero di coppie di definizioni: * - La prima indica il tipo di definizione * - La seconda la lunghezza nel record R * 3212 = Numero riga testo break * 3213 = Allineamento (LEFT CENTER RIGHT) * 3214 = Testo. T 3210 001 003 3212 001 3213 007 3214 050 R 1 RIGHT Totale comune di &3 E E questo è il programmino che va a mettere la data nel source del FORM per poter far vedere all'utente i parametri selezionati. /COPY qcpylesrc,hheader1 h************************************************************************** h* CL01 - Inserisce un campo in un form query nella sezione intestazione. * h************************************************************************** fsqlform uf e disk rename(sqlform:sql) f************************************************************************** d***************************************************************** d**** Dichiarazione campi *** d***************************************************************** d dati s 100 d len s 4 0 d pos s 4 0 d si c const(*on) d no c const(*off) dutility sds d programma *proc d utente 254 263 c* c* Scandisce membro sqlform e cerca la sezione interessata. c* c do *hival c read sql c if %eof c leave c endif c if %subst(srcdta:1:6)='T 1210' c* c* Trovata, scandisce prossime righe, sono ammessi solo commenti o righe tipo "R" c* in caso contrario esce e non aggiorna. c* c do *hival c read sql c if %eof c leave c endif c if %subst(srcdta:1:1)='*' Commenti, salta. c iter c endif c if %subst(srcdta:1:1)='R' Record "R" va bene c eval pos=%scan('&':srcdta) Vede se trova il c if pos=0 carattere speciale c iter c endif c if pos+len-1>%len(srcdta) Se la stringa da in- c eval len=%len(srcdta)-pos+1 serire è troppo lun- c endif ga la ridimensiona. c eval %subst(srcdta:pos:len)=%trim(dati) Inserisce c update sql Aggiorna. c leave c else Non "R" esce e non c leave aggiorna c endif c enddo c* c endif c* c enddo c eval *inlr=*on /EJECT c********************************************************************************************* c* *INZSR - Partenza standard * c*-------------------------------------------------------------------------------------------* c* Ricezione parametri e verifica autorizzazione all'uso del programma * c*-------------------------------------------------------------------------------------------* c* Parametri passati ricevuti: * c* AUTORIZZAZI O - Autorizzazioni concesse * c*-------------------------------------------------------------------------------------------* c* Indicatori utilizzati: * c* xx - On Off - Descrizione * c*-------------------------------------------------------------------------------------------* c* Routine richiamate: * c* xxxxxxxxxxx - Descrizione * c********************************************************************************************* c *inzsr begsr c* c *entry plist c parm dati c eval len=%len(%trim(dati)) c* c endsr
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.