Hola, lo del ACCESS MODE IS DYNAMIC yo lo tengo
despu�s de ORGANIZATION, no s� si afectar�. Otra cosa, inicializa correctamente
los 3 campos de la clave del start.
MOVE CRMSIC(4:10) TO CLAVE1 OF
LKIC2OG3
Pon a qu� fichero pertenecen no sea que CLAVE1
tambi�n sea un campo en pantalla
tc... .
SELECT BQ ASSIGN TO
DATABASE-BQ
ORGANIZATION INDEXED ACCESS DYNAMIC
RECORD KEY IS EXTERNALLY-DESCRIBED-KEY STATUS FST.
ORGANIZATION INDEXED ACCESS DYNAMIC
RECORD KEY IS EXTERNALLY-DESCRIBED-KEY STATUS FST.
Si sigue sin pirular quita la B de binary
en
88 SI-EXISTE-OG VALUE B"1".
y define la variable a nivel 77 no 03
hay cosas que no deber�an influir
pero...
saludos,
Juan Enrique.
----- Original Message -----
From: "RUBIO-ENRIQUEZ Franc" <[EMAIL PROTECTED]>
To: "Forum Help/400" <[EMAIL PROTECTED]>
Sent: Thursday, June 10, 2004 11:57 AM
Subject: Instrucci�n START en
Cobol/400
me est� despistando el START y READ NEXT para un fichero que tiene 3 claves y solo s� el valor de las 2 primeras y la tercera es una fecha.
Bien, os muestro el estado del tema:
Registro-1 Clave1: 16908 Clave2: ES 00057 Clave3: 2004-05-15
Registro-2 Clave2: 16908 Clave2: ES 00058 Clave3: 2004-05-15
Las sentencias Cobol son las siguientes:
SELECT LKIC3OG3 ASSIGN TO DATABASE-LKIC3OG3
ORGANIZATION IS INDEXED
RECORD KEY IS EXTERNALLY-DESCRIBED-KEY
WITH DUPLICATES
ACCESS IS DYNAMIC.
---------------------------------------------------------------------
03 EXISTE-OG PIC X.
88 SI-EXISTE-OG VALUE B"1".
88 NO-EXISTE-OG VALUE B"0".
03 FIN-OG PIC X.
88 SI-FIN-OG VALUE B"1".
88 NO-FIN-OG VALUE B"0".
-------------------------------------------------------------------------------
9100-SITUAR-OG.
MOVE "1" TO EXISTE-OG.
START LKIC3OG3 KEY NOT < EXTERNALLY-DESCRIBED-KEY
INVALID MOVE "0" TO EXISTE-OG.
9100-SITUAR-OG-X.
EXIT.
9110-LEER-OG.
MOVE "0" TO FIN-OG.
READ LKIC3OG3 NEXT AT END MOVE "1" TO FIN-OG.
9110-LEER-OG-X.
EXIT.
---------------------------------------------------------------------------
MOVE CRMSIC(4:10) TO CLAVE1
MOVE T-LNK-PRE(P) TO CLAVE2
MOVE "0001-01-01" TO CLAVE3
PERFORM 9100-SITUAR-OG THRU 9100-SITUAR-OG-X
IF SI-EXISTE-OG
PERFORM 9110-LEER-OG THRU 9110-LEER-OG-X
PERFORM
UNTIL SI-FIN-OG
OR OGDEAP NOT = CLAVE1
OR OGR6CF NOT = CLAVE2
PERFORM 2200-DESCRIP THRU 2200-DESCRIP-X
END-PERFORM
END-IF
-----------------------------------------------------------------
Bueno, pu�s del START el switch me dice que ha encontrado algo donde posicionarse ya que lo hace por NOT < (es decir mayor o igual).
Al hacer el READ NEXT, curiosamente me lee el segundo registro y no el primero que pensaba que era el registro MAYOR (debido a la fecha le�da).
Entonces no me cumple la tercera condici�n del PERFORM.
Yo que vengo de programar en RPG, con SETLL y READ, y con claves parciales hay cosas del Cobol que no comprendo.
�Me pod�is ayudar?
Muchas gracias de antemano.
Francisco Rubio Enr�quez
Analista
Cibernos Consulting, SAU
-- Disclaimer ------------------------------------
Ce message ainsi que les eventuelles pieces jointes constituent une correspondance privee et confidentielle a l'attention exclusive du destinataire designe ci-dessus. Si vous n'etes pas le destinataire du present message ou une personne susceptible de pouvoir le lui delivrer, il vous est signifie que toute divulgation, distribution ou copie de cette transmission est strictement interdite. Si vous avez recu ce message par erreur, nous vous remercions d'en informer l'expediteur par telephone ou de lui retourner le present message, puis d'effacer immediatement ce message de votre systeme.
***
This e-mail and any attachments is a confidential correspondence intended only for use of the individual or entity named above. If you are not the intended recipient or the agent responsible for delivering the message to the intended recipient, you are hereby notified that any disclosure, distribution or copying of this communication is strictly prohibited. If you have received this communication in error, please notify the sender by phone or by replying this message, and then delete this message from your system.
_____________________________________________________
Forum.HELP400 es un servicio m�s de NEWS/400.
� Publicaciones Help400, S.L. - Todos los derechos reservados
http://www.help400.es
_____________________________________________________
Para darte de baja, env�a el mensaje resultante de pulsar
mailto:[EMAIL PROTECTED]
