|
|
|
|
|
- Lecture selon une clé
- Comparaison des fonctions HPrécédent et HLitPrécédent
- Divers
- Blocages
HPrécédent (Fonction) En anglais : HPrevious
Non disponible avec ce type de connexion
Positionne sur l'enregistrement précédent du fichier de données en fonction d'une rubrique de parcours. L'enregistrement n'est pas lu.
Le numéro de l'enregistrement en cours est modifié uniquement lorsqu'il est renvoyé par la fonction HNumEnr. Pour les fonctions manipulant par défaut le numéro de l'enregistrement en cours (fonctions HSupprime, HLit, HModifie, ...), la valeur de ce numéro n'est pas mise à jour : il faut utiliser la fonction HNumEnr(). Par exemple : ne pas faire :
mais
HSupprime(Client, HNumEnr())
La lecture se fait de la plus petite à la plus grande valeur de la rubrique de parcours (consultez les remarques pour plus de détails). Attention : L'enregistrement chargé en mémoire n'est pas modifié. Les variables HFSQL (par exemple Client.Nom, c'est-à -dire la rubrique Nom du fichier Client) ne sont pas mises à jour. En général, la fonction HPrécédent permet de se positionner dans le fichier de données pour effectuer une boucle de parcours parmi les enregistrements correspondant à une condition. La fonction HSuivant permet de se positionner sur l'enregistrement suivant correspondant à la condition. Après l'exécution de la fonction HPrécédent, plusieurs cas peuvent se présenter : - un enregistrement correspondant à la condition a été trouvé : la fonction HTrouve renvoie Vrai
- le fichier de données est vide ou il n'existe pas d'enregistrement correspondant à la condition : la fonction HEnDehors renvoie Vrai
Remarques : - Par défaut, les fonctions HRecherchePremier et HRechercheDernier permettent de réaliser une recherche à l'identique.
- Par défaut, la fonction HPrécédent effectue une recherche générique.
La lecture se fait de la plus grande valeur à la plus petite valeur de la rubrique de parcours (consultez les remarques pour plus de détails). Attention : L'enregistrement chargé en mémoire n'est pas modifié. Les variables HFSQL (par exemple Client.Nom, c'est-à -dire la rubrique Nom du fichier Client) ne sont pas mises à jour. En général, la fonction HPrécédent permet de se positionner dans le fichier de données lors d'une boucle de parcours. Après l'exécution de la fonction HPrécédent, plusieurs cas peuvent se présenter : - le fichier de données est vide ou il n'existe pas d'enregistrement correspondant au filtre (défini par HFiltre) : la fonction HEnDehors renvoie Vrai.
- la fonction tente de bloquer un enregistrement déjà bloqué en lecture : la fonction HErreurBlocage renvoie Vrai et la fonction HEnDehors renvoie Vrai.
Accès par JDBC : La gestion des blocages n'est pas disponible sur les bases de données accédées par JDBC.
HDernier(Client, Nom) TANTQUE HEnDehors() = Faux // Traitement de l'enregistrement HPrécédent(Client, Nom) FIN
Syntaxe
<Résultat> = HPrécédent([<Fichier de données> [, <Rubrique clé de parcours>] [, <Options>]])
<Résultat> : Booléen - Vrai si le positionnement sur l'enregistrement a été effectué,
- Faux en cas d'erreur. Ce problème peut être dû :
- soit à un problème de positionnement (fichier de données vide, ...) : la fonction HTrouve renvoie Faux et HErreur renvoie 0.
- soit à une erreur : la fonction HErreur renvoie un entier différent de 0. La fonction HErreurInfo permet d'obtenir plus de détails.
<Fichier de données> : Chaîne de caractères optionnelle Nom du fichier de données HFSQL manipulé. Si ce paramètre correspond à une chaîne vide, la fonction HPrécédent manipule le dernier fichier de données utilisé par la dernière fonction de gestion HFSQL (fonction commençant par la lettre H). <Rubrique clé de parcours> : Chaîne de caractères optionnelle Nom de la rubrique clé utilisée pour parcourir le fichier de données. Si ce nom n'est pas spécifié, la fonction HPrécédent va manipuler la dernière rubrique de parcours utilisée sur ce fichier par la dernière fonction de gestion HFSQL (fonction commençant par la lettre H). Si cette rubrique n'existe pas, la meilleure rubrique de parcours est automatiquement utilisée. <Options> : Constante optionnelle Paramètre le blocage et la gestion des doublons réalisés sur l'enregistrement sélectionné par la fonction HPrécédent : | | hBlocageEcriture | Blocage en écriture : l'enregistrement sélectionné pourra être lu par une autre application mais ne pourra pas être modifié par une autre application. | hBlocageLectureEcriture | Blocage en lecture/écriture : l'enregistrement sélectionné ne pourra ni être lu ni être modifié par une autre application. | hBlocageNon | Aucun blocage : l'enregistrement pourra être lu ou modifié par une autre application. | hDistinct | Si des doublons sont présents, permet de se positionner uniquement sur un seul enregistrement parmi les doublons. Ce paramètre est pris en compte uniquement si le parcours est réalisé sur une rubrique clé. Par défaut, tous les doublons sont parcourus. |
Remarques Lecture selon une clé La fonction HPrécédent positionne sur l'enregistrement pour lequel la valeur de la clé est la plus grande. L'ordre de tri pris en compte est l'ordre de tri spécifié dans l'analyse pour cette clé. Comparaison des fonctions HPrécédent et HLitPrécédent La fonction HPrécédent ne lit pas l'enregistrement : la fonction HPrécédent est donc plus rapide que la fonction HLitPrécédent.
Documentation également disponible pour…
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|