IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

VB 6 et antérieur Discussion :

[VB6]Message d'erreur si le temps d'exécution est trop long


Sujet :

VB 6 et antérieur

  1. #1
    Membre éclairé
    Avatar de Asdorve
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 332
    Points : 718
    Points
    718
    Par défaut [VB6]Message d'erreur si le temps d'exécution est trop long
    Bonjour,

    Voilà donc mon problème:

    je récupère des infos dans une base de données et je les affiche dans un datagrid.

    Des fois, si quelqu'un est dans l'enregistrement que je veux récupérer, le programme s'arrête et reprend une fois que l'autre personne a fini de consulter l'enreg en question.

    Comment je peux faire pour afficher un message lorsque le temps d'exécution dépasse 20 secondes par exemple?

    Merci beaucoup pour votre aide.
    Xavier

  2. #2
    Membre confirmé Avatar de totoche
    Inscrit en
    Janvier 2004
    Messages
    1 090
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 1 090
    Points : 558
    Points
    558
    Par défaut
    Associer un timer avec Connection.state n'est pas une bonne solution?
    La patience est un arbre aux racines amères, mais aux fruits ci-doux.

  3. #3
    Membre éclairé
    Avatar de Asdorve
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 332
    Points : 718
    Points
    718
    Par défaut
    Peut-être. Je ne connais pas...

    EDIT:

    Voici où ça bloque quand un autre utilisateur est dans l'enregistrement (en rouge):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
      'on effectue la requête sql en tenant compte de DateDéfinitve
        cmdADO.CommandText = "SELECT..."
    
        'Configurer le recordset
        'si le recordset est déjà ouvert on le ferme
            If rsADO.State = adStateOpen Then
            rsADO.Close
        End If
        'Curseur client
        rsADO.CursorLocation = adUseClient
        'curseur dynamique
        rsADO.CursorType = adOpenDynamic
        'on verrouille l'enregistrement des accès dans la source de données
        rsADO.LockType = adLockPessimistic
        
        'ouverture du recordset
        rsADO.Open cmdADO
    Xavier

  4. #4
    Membre confirmé Avatar de totoche
    Inscrit en
    Janvier 2004
    Messages
    1 090
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 1 090
    Points : 558
    Points
    558
    Par défaut
    une piste avec Jet OLEDB:Lock Delay

    J'ai trouvé ça
    http://bidou.ftp-developpez.com/Cour...ype%20ADODB%22


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    TaConnexion.Properties("Jet OLEDB:Lock Delay") = 20000
    La patience est un arbre aux racines amères, mais aux fruits ci-doux.

  5. #5
    Membre éclairé
    Avatar de Asdorve
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 332
    Points : 718
    Points
    718
    Par défaut
    j'utilise pas OLEDB pour me connecter

    j'utilise ADODB. Je vais voir s'il n'existe pas cette propriété aussi pour ADODB.

    Merci
    Xavier

  6. #6
    Membre éclairé
    Avatar de Asdorve
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 332
    Points : 718
    Points
    718
    Par défaut
    j'ai fait ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
        cnnADO.Properties("ADODB:Lock Delay") = 20000
    ça a pas l'air de marcher.
    Xavier

  7. #7
    Membre confirmé Avatar de totoche
    Inscrit en
    Janvier 2004
    Messages
    1 090
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 1 090
    Points : 558
    Points
    558
    Par défaut
    ADO ne permet pas de se connecter directement à une base de données particulière : cette API passe obligatoirement par OLE DB.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    cnnADO.Properties("Jet OLEDB:Lock Delay") = 20000
    La patience est un arbre aux racines amères, mais aux fruits ci-doux.

  8. #8
    Membre éclairé
    Avatar de Asdorve
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 332
    Points : 718
    Points
    718
    Par défaut
    Message d'erreur sur cette ligne:

    Impossible de trouver l'objet dans la collection correspondant au nom ou à la référence ordinale demandé
    Xavier

  9. #9
    Membre confirmé Avatar de totoche
    Inscrit en
    Janvier 2004
    Messages
    1 090
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 1 090
    Points : 558
    Points
    558
    Par défaut
    Aie tu utilises cnnADO.Provider = "MSDataShape"
    La patience est un arbre aux racines amères, mais aux fruits ci-doux.

  10. #10
    Membre éclairé
    Avatar de Asdorve
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 332
    Points : 718
    Points
    718
    Par défaut
    non, je passe un DSN

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
     
    'Déclaration des variables locales
        Dim strInput As String
     
        InitConnection = False
        'Initialisation de la chaine de connexion
        cnnADO.ConnectionString = "DSN=GTI;"
     
        'Vérifie que la connexion est bien fermée
        If cnnADO.State = adStateOpen Then
            cnnADO.Close
        End If
     
        'Connexion à la base de données
        cnnADO.Open cnxString, GTI, GTI, adSyncConnect
     
        'Attente que la connexion soit établie
        While (cnnADO.State = adStateConnecting)
            DoEvents
        Wend
     
        'Vérification des erreurs dans le cas d'une mauvaise connexion
        If cnnADO.Errors.Count > 0 Then
     
            'Affichage des erreurs
            MsgBox cnnADO.Errors.Item(0)
            InitConnection = False
            Exit Function
     
            Else
                InitConnection = True
        End If
     
        cmdADO.ActiveConnection = cnnADO
    Xavier

  11. #11
    Membre éclairé
    Avatar de Asdorve
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 332
    Points : 718
    Points
    718
    Par défaut
    Bon, j'ai utilisé .CommandTImeOut

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
     
    ...
    On Error GoTo Erreur
        'ouverture du recordset
        MonErreur = "TimeOut"
        cmdADO.CommandTimeout = 10
         MonErreur = ""
        rsADO.Open cmdADO
     
    Exit Sub
     
    Erreur:
    If MonErreur = "TimeOut" Then
        MsgBox ("Une autre personne utilise la ressource. Réessayez ultérieurement.")
    Else
        ...
    End If
    ...
    Voilà!

    @+
    Merci à totoche qui a répondu!
    Xavier

  12. #12
    Membre éclairé
    Avatar de Asdorve
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 332
    Points : 718
    Points
    718
    Par défaut
    Citation Envoyé par Asdorve
    Bon, j'ai utilisé .CommandTImeOut

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
     
    ...
    On Error GoTo Erreur
        'ouverture du recordset
        MonErreur = "TimeOut"
        cmdADO.CommandTimeout = 10
         MonErreur = ""
        rsADO.Open cmdADO
     
    Exit Sub
     
    Erreur:
    If MonErreur = "TimeOut" Then
        MsgBox ("Une autre personne utilise la ressource. Réessayez ultérieurement.")
    Else
        ...
    End If
    ...
    Bonjour,

    je reviens sur ce que j'ai dit.
    Après des tests, il apparait que .CommandTimeOut ne s'applique que lorsque je fais cmdADO.ActiveConnection = cnnADO, mais pas lorsque je fais rsADO.Open cmdADO.

    Je rappelle donc le problème: si quelqu'un lit un enregistrement de la table, on bloque ici: rsADO.Open cmdADO

    Comment je peux faire pour au moins lire les données qui sont déjà lues pas quelqu'un d'autre?

    Merci
    Xavier

  13. #13
    Membre éclairé
    Avatar de Asdorve
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 332
    Points : 718
    Points
    718
    Par défaut
    Personne n'a d'idée?
    Xavier

  14. #14
    Membre confirmé Avatar de totoche
    Inscrit en
    Janvier 2004
    Messages
    1 090
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 1 090
    Points : 558
    Points
    558
    Par défaut
    Peux tu changer le verrouillage du curseur en optimiste?
    La patience est un arbre aux racines amères, mais aux fruits ci-doux.

  15. #15
    Membre éclairé
    Avatar de Asdorve
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 332
    Points : 718
    Points
    718
    Par défaut
    salut,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    'Curseur client
        rsADO.CursorLocation = adUseClient
    'curseur dynamique
        rsADO.CursorType = adOpenDynamic
        
    'on verrouille l'enregistrement des accès dans la source de données
        rsADO.LockType = adLockOptimistic
    j'ai toujours le même problème.
    Xavier

  16. #16
    Membre expert
    Avatar de Delbeke
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    2 675
    Détails du profil
    Informations personnelles :
    Âge : 70
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 2 675
    Points : 3 696
    Points
    3 696
    Par défaut
    Avec dao, les tables ne sont verouillées que le temps entre le Edit/AddNew et le update. De plus seul un blocks de 4 ko est verouillé pour chaque edit/addnew : celui contenant le recordset
    Je ne sais pas pour ado
    En général, on ne demande de conseils que pour ne pas les suivre ou, si on les a suivis, reprocher à quelqu'un de les avoir donnés
    (ALEXANDRE DUMAS)

    N'hésitez pas à visiter ma page de contributions

  17. #17
    Membre éclairé
    Avatar de Asdorve
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 332
    Points : 718
    Points
    718
    Par défaut
    SAlut DElbeke,

    je viens de faire le test suivant:

    -personne ne lit les données,
    -je lance l'appli et ça marche.

    -moi et moi seul lis un enregistrement,
    -le programme plante,
    -je sors de l'enregistrement,
    -le programme reprend et se termine correctement.
    Xavier

Discussions similaires

  1. Erreur OEM 10gR2 - Temps d'exécution des requêtes
    Par fabien.morel2002 dans le forum Administration
    Réponses: 0
    Dernier message: 30/11/2009, 16h00
  2. Proc ASSIGN temps d'exécution très, trop long
    Par bdbdb dans le forum SAS STAT
    Réponses: 1
    Dernier message: 02/03/2009, 16h39
  3. [VB6] Message d'erreur
    Par fourgeaud dans le forum VB 6 et antérieur
    Réponses: 11
    Dernier message: 13/06/2006, 18h14
  4. [VB6] Message d'erreur: Projet ou bibliotheque introuvable
    Par bvi67 dans le forum VB 6 et antérieur
    Réponses: 10
    Dernier message: 20/05/2006, 12h00
  5. Message d'erreur Windows lors de l'exécution de l'appli D6-
    Par kolac dans le forum Bases de données
    Réponses: 4
    Dernier message: 07/12/2004, 17h55

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo