ONLINE HELP
 WINDEVWEBDEV AND WINDEV MOBILE

Help / WLanguage / Managing databases / HFSQL / Managing transactions / WLanguage functions
  • Manipulations d'enregistrements pendant une transaction
  • Transactions et contexte HFSQL indépendant
WINDEV
WindowsLinuxUniversal Windows 10 AppJavaEtats et RequêtesCode Utilisateur (MCU)
WEBDEV
WindowsLinuxPHPWEBDEV - Code Navigateur
WINDEV Mobile
AndroidWidget AndroidiPhone/iPadWidget IOSApple WatchMac CatalystUniversal Windows 10 App
Autres
Procédures stockées
Permet de savoir si une transaction a été interrompue (la transaction n'a été ni validée, ni annulée). Les caractéristiques de la transaction interrompue peuvent être connues grâce à des variables HFSQL.
Il est conseillé d'utiliser cette fonction dans le code d'initialisation du projet. Si la transaction est interrompue, il est par exemple possible :
  • HFSQL Classic soit de lancer WDTRANS ou WDOptimizer.
  • HFSQL Client/Serveur soit de lancer le Centre de Contrôle HFSQL.
  • soit d'annuler la transaction par programmation.
HFSQL Client/Serveur Cette fonction est utile principalement si des transactions ont été interrompues sur des fichiers de données protégés par mots de passe.
AndroidWidget AndroidiPhone/iPadWidget IOSMac Catalyst La gestion des transactions est disponible uniquement pour les bases de données HFSQL Client/Serveur.
Exemple
SI HTransactionInterrompue("") = Vrai ALORS
HTransactionAnnule()
FIN
Syntaxe
<Résultat> = HTransactionInterrompue([<Fichier de transaction>])
<Résultat> : Booléen
  • Vrai si une transaction a été interrompue,
  • Faux si aucune transaction n'a été interrompue. Les variables HFSQL suivantes sont mises à jour :
    H.TrsIdInterneValeur si la transaction a été interrompue : Numéro interne identifiant de manière unique la transaction.
    Valeur si la transaction n'a pas été interrompue : -1
    H.TrsNomApplicationValeur si la transaction a été interrompue : Nom de l'application sous la forme : Nom de l'exécutable(Nom du projet).
    Valeur si la transaction n'a pas été interrompue : Chaîne vide ("").
    Remarque : Cette variable est disponible uniquement en mode HFSQL Client/Serveur.
    H.TrsNomMachineValeur si la transaction a été interrompue : Nom du poste client et adresse IP du poste Client.
    Valeur si la transaction n'a pas été interrompue : Chaîne vide ("").
    Remarque : Cette variable est disponible uniquement en mode HFSQL Client/Serveur.
    H.TrsPosteValeur si la transaction a été interrompue : Identifiant défini par la fonction HPoste ou nom de la machine à partir de laquelle la transaction a été lancée.
    Valeur si la transaction n'a pas été interrompue : Chaîne vide ("")
<Fichier de transaction> : Chaîne de caractères optionnelle
Nom complet du fichier de transaction (utilisé pour enregistrer les opérations réalisées en transaction). Ce fichier est automatiquement détruit lors de l'utilisation des fonctions HTransactionFin ou HTransactionAnnule.
Si ce nom correspond à une chaîne vide ("") ou n'est pas précisé, le fichier de transaction utilisé est le fichier de transaction par défaut (dans le répertoire de l'application avec pour nom : <Nom Projet>_$TRS_OPERATION.trs).
HFSQL Client/Serveur Ce paramètre n'est pas pris en compte pour les transactions Client/Serveur, mais uniquement pour les transactions HFSQL Classic.
Remarques

Manipulations d'enregistrements pendant une transaction

Pendant une transaction, il est nécessaire de suivre certaines règles lors de la manipulation des enregistrements. Pour plus de détails, consultez Transactions : Manipuler les enregistrements lors d'une transaction.

Transactions et contexte HFSQL indépendant

Lors de la copie de contexte, si une transaction est en cours sur le premier contexte, le nouveau contexte n'est pas en transaction. Il faut rappeler la fonction HTransactionDébut (ou la fonction HTransaction) pour démarrer une transaction dans le nouveau contexte.
Classification Métier / UI : Code métier
Composante : wd290hf.dll
Minimum version required
  • Version 9
Comments
Base de données ou Serveur ? Quelle connexion ?
Est-ce que la fonction s'applique à l'ensemble des bases de données sur le serveur HFSQL ou bien sur une seule base de données ?

Dans tous les cas, comment peut-on lier une connexion existante sur le serveur à la fonction elle-même ?

Comment WinDev détermine-t-il quelle connexion il va utiliser pour exécuter la fonction ?
Sylvain Larue
11 Oct. 2022
Type de variable Connexion
Si vous déclarez une variable de type Connexion en globale avant le HTransactionInterrompue(..) et que vous n'utilisez pas cette variable à chaque fois (HF Classic ou HF C/S), la fonction vous renvoie une erreur si tous les paramètres de la connexion ne sont pas renseignés.

Mais cela veut dire (non testé), que la fonction se serait connectée sur le HF C/S dans tous les cas ?
lo²
15 Mar. 2016

Last update: 07/19/2023

Send a report | Local help