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

VBA Access Discussion :

sql INSERT contre contrainte CHECK [AC-2007]


Sujet :

VBA Access

  1. #1
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 590
    Points
    3 590
    Billets dans le blog
    8
    Par défaut sql INSERT contre contrainte CHECK
    Salut à toutes et à tous
    J'ai mis une contrainte check dans une de mes tables (un élève ne peut être dans plus d'une classe pour une année donnée). Mais voila quand je tente de faite un INSERT à partir de VBA je reçois un message "ACCESS n'a pas ajouter 1 enregistrement à cause d'une contrainte...."; que clic sur OUI ou NON pas de problème (ni les données ni mon programme frontal). Mais pour la même session si je tente une deuxième fois ACCESS plante et tente de réparer mon programme frontal.
    Existe-t-il une possibilité d'intercepter l'erreur liée à la violation d'intégrité.
    Ce tuto nous dit comment le faire avec un formulaire lié mais pas avec un INSERT dans VBA.
    Pour ce qui est du contrôle du style dcount ou recordcount de DAO, poser une contrainte ne serait plus de la peine .
    Merci d'avance.
    Le monde est trop bien programmé pour être l’œuvre du hasard…
    Mon produit pour la gestion d'école: www.logicoles.com

  2. #2
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    12 621
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 12 621
    Points : 56 866
    Points
    56 866
    Billets dans le blog
    40
    Par défaut
    Salut alassanediakite,

    j'ai moi-même expérimenté ces contraintes de table CHECK.

    Je ne sais pas si ton problème est du même genre que le mien mais il semblerait que selon la complexité de la requête, spécialement si elle fait appel à une sous-requête sur la même table, des problèmes de stabilité peuvent apparaître sur des Insert/Delete.

    Tu peux constater le problème dans la discussion ici.

  3. #3
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    tu peux montrer ton code VBA ?

  4. #4
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 590
    Points
    3 590
    Billets dans le blog
    8
    Par défaut
    Salut
    Voici l'évènement du bouton.
    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
    Private Sub valider_orientation_Click()
    On Error GoTo Err_valider_orientation_Click
    Dim requeteajout As String
     
     
    If IsNull(Me.annee) Or IsNull(Me.classe) Then
    MsgBox "Saisissez toutes les information!", vbExclamation
    Exit Sub
    End If
     
    requeteajout = "INSERT INTO TBligneclasse_lncls ( idcls, idelv ) SELECT " & Me.classe & " AS cls, " & Me.eleve & " AS elv;"
     
    DoCmd.RunSQL requeteajout
        'ferme le formulaire
        DoCmd.Close
     
    Exit_valider_orientation_Click:
      Exit Sub
     
    Err_valider_orientation_Click:
    On Error GoTo erinconnu
     
        MsgBox Err.Number & " " & Err.description
        Resume Exit_valider_orientation_Click
    erinconnu:
    MsgBox "erreur inconnue"
    End Sub
    Comme je l'ai dis le code ne pose pas de problème si la contrainte n'est pas violée ou si elle l'est mais pour une première fois.
    Merci d'avance.
    Le monde est trop bien programmé pour être l’œuvre du hasard…
    Mon produit pour la gestion d'école: www.logicoles.com

  5. #5
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    Et en remplaçant le docmd.runsql par un Currentdb.Execute ?

  6. #6
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 590
    Points
    3 590
    Billets dans le blog
    8
    Par défaut
    Salut
    Cela marche bien. Voici le code
    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
    On Error GoTo Err_valider_orientation_Click
    Dim requeteajout As String
    If IsNull(Me.annee) Or IsNull(Me.classe) Then
    MsgBox "Saisissez toutes les information!", vbExclamation
    Exit Sub
    End If
    requeteajout = "INSERT INTO TBligneclasse_lncls ( idcls, idelv ) SELECT " & Me.classe & " AS cls, " & Me.eleve & " AS elv;"
    'Demarre la transaction
    On Error GoTo transERROR
    DBEngine.Workspaces(0).BeginTrans
    CurrentDb.execute requeteajout, dbConsistent + dbFailOnError 
    DBEngine.Workspaces(0).CommitTrans
     
    DoCmd.Close
    GoTo fintrans
    transERROR:
    DBEngine.Workspaces(0).Rollback
        If Err.Number = 3317 Then
        MsgBox "Cet élève est déjà dans une classe pour l'année choisie!", vbInformation, "Erreur d'orientation"
        Else
        MsgBox Err.Number & " " & Err.description
        End If
    fintrans:
    Exit Sub
     
    Err_valider_orientation_Click:
        MsgBox Err.Number & " " & Err.description
    End Sub
    Merci à tous.
    Le monde est trop bien programmé pour être l’œuvre du hasard…
    Mon produit pour la gestion d'école: www.logicoles.com

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [SQL SERVER 2008 R2] Contrainte CHECK
    Par nadjibnet dans le forum MS SQL Server
    Réponses: 15
    Dernier message: 05/01/2011, 00h05
  2. Contrainte Check en SQL
    Par Identifiant dans le forum Langage SQL
    Réponses: 1
    Dernier message: 03/02/2008, 17h37
  3. SQL 2k5 - Bulk Insert et contrainte identity
    Par Luc1an0 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 08/01/2008, 19h35
  4. [SQL Server 2000] Contrainte Check et exception générée
    Par Greldinard dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 01/09/2006, 12h36
  5. [SQL Server 2000] Contrainte check
    Par batosai dans le forum Langage SQL
    Réponses: 3
    Dernier message: 24/04/2006, 16h16

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