Codifique sentencias ESQL para acceder a los campos de la cabecera MQCFH (nombre de raíz MQPCF).
Los mensajes que tienen formato PCF (MQPCF, MQADMIN y MQEVENT) incluyen la cabecera MQCFH. Puede procesar el contenido de la cabecera MQCFH, accediendo a parámetros, listas de parámetros, series y grupos.
Puede implementar su propio campo ParameterCount con un valor específico, pero el número real de parámetros en la salida de flujo sobrescribirá este valor.
SET OutputRoot.MQPCF.Parameter[nn] =
ID parámetro entero
Si
accede a un parámetro de 64 bits, utilice la sintaxis siguiente para diferenciar de los parámetros de 32 bits:SET OutputRoot.MQPCF.Parameter64[nn] =
ID parámetro entero
Por ejemplo,SET OutputRoot.MQPCF.Parameter[1] =
MQCACF_AUTH_PROFILE_NAME;
SET OutputRoot.MQPCF.ParameterList64[nn] =
ID parámetro entero
SET OutputRoot.MQPCF.ParameterList64[nn].*[xx] =
valores parámetro entero
Por ejemplo,SET OutputRoot.MQPCF.ParameterList[1] =
MQIACF_AUTH_ADD_AUTHS;
SET OutputRoot.MQPCF.ParameterList[1].*[1] =
MQAUTH_SET;
SET OutputRoot.MQPCF.ParameterList[1].*[2] =
MQAUTH_SET_ALL_CONTEXT;
SET OutputRoot.MQPCF.Parameter[nn] =
ID parámetro entero
SET OutputRoot.MQPCF.Parameter[nn].* =
Valor de parámetro entero, serie o matriz de bytes
SET
OutputRoot.MQPCF.Group[xx] =
ID parámetro grupo
Por ejemplo,SET OutputRoot.MQPCF.Group[1] =
MQGACF_Q_ACCOUNTING_DATA;
SET OutputRoot.MQPCF.Group[1].Parameter[1] =
MQCA_CREATION_DATE;
SET OutputRoot.MQPCF.Group[1].Parameter[1].* =
'2007-02-05';
También puede utilizar grupos anidados; por ejemplo;SET
OutputRoot.MQPCF.Group[1].Group[1] =
MQGACF_Q_ACCOUNTING_DATA;
SET OutputRoot.MQPCF.Group[1].Group[1].Parameter[1] =
MQCA_CREATION_DATE;
SET OutputRoot.MQPCF.Group[1].Group[1].Parameter[1].* =
'2007-02-05';
SET OutputRoot.MQPCF.Filter[xx] =
ID parámetro entero
SET OutputRoot.MQPCF.Filter[xx].Operator =
Nombre filtro de enteros
SET OutputRoot.MQPCF.Filter[xx].Value =
Valor de filtro de byte, entero o serie
CREATE NEXTSIBLING OF OutputRoot.Properties DOMAIN 'MQMD';
CREATE NEXTSIBLING OF OutputRoot.MQMD DOMAIN 'MQADMIN'
NAME 'MQPCF';
CREATE FIELD OutputRoot.MQPCF;
SET OutputRoot.MQMD.MsgType = MQMT_REQUEST;
SET OutputRoot.MQMD.ReplyToQ = 'REPLYQ';
DECLARE refRequest REFERENCE TO OutputRoot.MQPCF;
SET refRequest.Type = 16; --MQCFT_COMMAND_XR z/OS
SET refRequest.StrucLength = MQCFH_STRUC_LENGTH;
SET refRequest.Version = 3; -- requerido para z/OS
SET refRequest.Command = MQCMD_INQUIRE_Q;
SET refRequest.MsgSeqNumber = 1;
SET refRequest.Control = MQCFC_LAST;
/* Primer parámetro: Nombre de cola. */
SET refRequest.Parameter[1] = MQCA_Q_NAME;
SET refRequest.Parameter[1].* = 'QUEUENAME.*';
SET refRequest.ParameterList[1] = MQIACF_Q_ATTRS;
SET refRequest.ParameterList[1].* = MQIACF_ALL;