ClubEnsayos.com - Ensayos de Calidad, Tareas y Monografias
Buscar

Sort Cobol


Enviado por   •  4 de Noviembre de 2013  •  8.494 Palabras (34 Páginas)  •  679 Visitas

Página 1 de 34

SORT vol.1: SORT, INCLUDE.

La estructura general de un SORT es la siguiente:

//SORT001 EXEC PGM=SORT,PARM=('DYNALLOC=(SYSALLDA,32)')

//SORTIN DD DSN=nombre.fichero.entrada1,DISP=SHR

// DD DSN=nombre.fichero.entrada2,DISP=SHR

//SORTOUT DD DSN=nombre.fichero.salida1,

// DISP=(,CATLG,DELETE),SPACE=(CYL,(500,100))

//SYSOUT DD SYSOUT=*

//SYSPRINT DD SYSOUT=*

//SYSIN DD *

PGM=SORT --> Indica el programa a utilizar, en este caso el SORT

PARM=('DYNALLOC=(SYSALLDA,32)') --> Cantidad de memoria que se da a la ejecución del paso. Si se queda corto, aumentarla en valores de 8,12,32,64,128, 256 (como las memorias RAM)

SORTIN --> Ficheros de entrada

SORTOUT --> Ficheros de salida

SYSIN --> Indica el tipo de sort a realizar, las opciones disponibles son muchas y muy variadas, pudiendo utilizarse varias juntas en un mismo paso. Algunas de ellas son SORT, SUM, OMIT, INCLUDE, INREC, OUTREC, OUTFIL, OPTION … .

En este documento se explica en detalle algunas de estas funciones:

SORT

SORT FIELDS --> Ordena los registros a partir del fichero de entrada y los guarda ordenados en el fichero de salida:

//SORT001 EXEC PGM=SORT,PARM=('DYNALLOC=(SYSALLDA,32)')

//SORTIN DD DSN=nombre.fichero.entrada1,DISP=SHR

// DD DSN=nombre.fichero.entrada2,DISP=SHR

//SORTOUT DD DSN=nombre.fichero.salida1,

// DISP=(,CATLG,DELETE),SPACE=(CYL,(500,100))

//SYSOUT DD SYSOUT=*

//SYSPRINT DD SYSOUT=*

//SYSIN DD *

SORT FIELDS=(I,L,T,O,I,L,T,O)

I – Inicio. Posición donde empieza el campo por el que se quiere ordenar

L – Longitud máxima del campo por el que se quiere ordenar

T – Tipo de dato del campo que se quiere ordenar:

CH --> Alfanumérico o numérico normal(sin COMP)

BI --> Hexadecimal (campos COMP)

PD --> Empaquetado con o sin signo(campos COMP-3)

O – Orden. A-Ascendente, D- Descendente

Ejemplo:

Ordenar el siguiente fichero por Número y Nombre de cliente en orden ascendente:

----+----1----+----2----+----3----+----4----+----5----+----6----+----7--

000000002JAVIER MARTINEZ CARRETEROASALARIADO

000000006ANTONIO VILLA SUSO AUTONOMO

000000005YOLANDA LOPEZ ALONSO AUTONOMO

000000001JOSE LOPEZ PITA AUTONOMO

000000004CARLOS POLO DEL BARROAUTONOMO

000000003CARLOS PEREZ FANO AUTONOMO

Fórmula:

SORT FIELDS=(1,9,CH,A,10,10,CH,A)

Resultado:

----+----1----+----2----+----3----+----4----+----5----+----6----+----7--

000000001JOSE LOPEZ PITA AUTONOMO

000000002JAVIER MARTINEZ CARRETEROASALARIADO

000000003CARLOS PEREZ FANO AUTONOMO

000000004CARLOS POLO DEL BARROAUTONOMO

000000005YOLANDA LOPEZ ALONSO AUTONOMO

000000006ANTONIO VILLA SUSO AUTONOMO

Otra opción que tiene el SORT es la siguiente:

SORT FIELDS=COPY

Con ella no indicamos ningún tipo de orden, por lo cual, el fichero de entrada se grabará en salida con el mismo orden.

INCLUDE

Filtra los registros deseados por la condición que se indique:

//SORT001 EXEC PGM=SORT,PARM=('DYNALLOC=(SYSALLDA,32)')

//SORTIN DD DSN=nombre.fichero.entrada1,DISP=SHR

// DD DSN=nombre.fichero.entrada2,DISP=SHR

//SORTOUT DD DSN=nombre.fichero.salida1,

// DISP=(,CATLG,DELETE),SPACE=(CYL,(500,100))

//SYSOUT DD SYSOUT=*

//SYSPRINT DD SYSOUT=*

//SYSIN DD *

SORT FIELDS=COPY

INCLUDE COND=(I,L,T,C,V)

I – Inicio. Posición donde empieza el campo por el que se quiere filtrar

L – Longitud máxima del campo por el que se quiere filtrar

T – Tipo de dato del campo que se quiere filtrar:

CH - Carácter o numérico normal(sin COMP)

BI - Hexadecimal (campos COMP)

C – Condición de la igualdad que se quiere realizar:

EQ – Igual

NE - Distinto

GE – Mayor o igual

GT - Mayor

LE – Menor o igual

LT - Menor

V – Valor del dato por el que se quiere filtrar

X’001A‘ – Indica un valor hexadecimal o empaquetado

C’AL12’ – Indica un valor alfanumérico

Ejemplos:

Ejemplo 1. Vamos a realizar un paso de SORT que realice un filtrado del fichero indicado, para quedarse con los clientes que cumplan lo siguiente: Sean AUTONOMOS y su número de teléfono sea un móvil (comience por 6):

Copy:

01 ENTRADA1.

05 ENTRADA1-NUMCLI PIC 9(9).

05 ENTRADA1-NOMBRE PIC X(10).

05 ENTRADA1-APELLID1 PIC X(10).

05 ENTRADA1-APELLID2 PIC X(10).

05 ENTRADA1-TIPO PIC X(11).

05 ENTRADA1-CATEGORIA PIC 9(9) COMP-3.

05 ENTRADA1-TLFNO PIC 9(9).

05 FILLER PIC X(9) VALUE SPACES.

Fichero entrada:

=COLS>

----+----1----+----2----+----3----+----4----+----5----+----6----+----7--

000000002JAVIER MARTINEZ CARRETEROASALARIADO 983275586

FFFFFFFFFDCECCD4444DCDECDCE44CCDDCECDDCECDCDCCCD400001FFFFFFFFF444444444

00000000211595900004193955900319953596121319914600000C983275586000000000

------------------------------------------------------------------------

000000006ANTONIO VILLA SUSO AUTONOMO 918514535

FFFFFFFFFCDEDDCD444ECDDC44444EEED44444CEEDDDDD44400003FFFFFFFFF444444444

00000000615365960005933100000242600000143656460000000C918514535000000000

------------------------------------------------------------------------

000000005YOLANDA LOPEZ ALONSO AUTONOMO 988453548

FFFFFFFFFEDDCDCC444DDDCE44444CDDDED444CEEDDDDD44400001FFFFFFFFF444444444

00000000586315410003675900000136526000143656460000000C988453548000000000

------------------------------------------------------------------------

000000001JOSE LOPEZ PITA AUTONOMO 676757687

FFFFFFFFFDDEC444444DDDCE44444DCEC44444CEEDDDDD44400001FFFFFFFFF444444444

...

Descargar como (para miembros actualizados) txt (51 Kb)
Leer 33 páginas más »
Disponible sólo en Clubensayos.com