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 :

problème VBA et requête ajout


Sujet :

VBA Access

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Avril 2008
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 129
    Par défaut problème VBA et requête ajout
    Bonjour, j'ai un code VBA (grâce à l'aide précieuse de Bernard Michel ) que j'ai légèrement modifié.
    Sa fonction:
    J'ai un formulaire avec un sous-formulaire en mode feuille de données qui a 4 colonnes: numéro production, année, mois, stock physique
    Le code VBA va (sur ouverture du formulaire) pour chaque numéro de production, me mettre dans mon formulaire et dans ma table pour une année demandée tous les mois de l'année.
    Ainsi, l'utilisateur a un formulaire qui s'affiche:
    1ère colonne le numéro de production (répété donc 12 fois), 2ème colonne l'année 2008 répétée 12 fois, 3ème colonne les 12 mois de l'année et 4ème colonne des 0 correspondants au stock physique que l'utilisateur pourra modifier

    Voici mon 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
    Private Sub Form_Open(Cancel As Integer)
    Dim I   As Integer  ' Représente les 12 mois, voir ci-dessous For-To-Next
    Dim Z   As Integer  ' Représente l'année (voir ci-dessous divers possibilités)
    Dim W As Integer
    Dim sql As String   ' Variable dans laquelle on inscrit un code SQL variable selon I & Z
     
    ' Z = Year(Date)    ' Première possibilité où Z prend la valeur de l'année en cours
    Z = InputBox("Saisir l'année ci-dessous", "Démo", Year(Date))   ' Interaction avec l'utilisateur (utile pour
                                                                    ' situation de fin d'année)
    W = Me.NUM_PRODUCTION.Value ' Représente le numéro de production qui va venir se mettre par défaut'
     
        For I = 1 To 12 ' I prend les 12 valeurs des 12 mois
            sql = "INSERT INTO [stock premier aout] ( mois, année, [num production] ) VALUES ( " & I & ", " & Z & "," & W & ")"
            DoCmd.RunSQL sql
        Next I
    End Sub
    Bien qu'il fonctionne bien, j'ai maintenant deux problèmes:
    -si l'année 2008 a été ajoutée (j'entends par là les 12 mois avec les 0 correspondants en stock physique), comment faire pour que si je réouvre mon formulaire, je n'ai pas à nouveau mes 12 lignes qui se recréées?
    -lorsque j'ouvre mon formulaire, 12 lignes s'ajoutent. Access me met donc 12 fois le message "vous aller ajouter un enregistrement...."
    Comment faire pour éviter ce message?

    Merci pour votre aide;
    élodie

  2. #2
    Membre chevronné
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    427
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 427
    Par défaut
    Bonjour,
    Pour la question du non ajout, tu peux passer par la création d'une clé primaire dans ta table : n° de production, année, mois.

    Pour la seconde tu peux ajouter
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    docmd.SetWarnings False
    DoCmd.RunSQL sql
    docmd.SetWarnings True
    Ce qui désactive les avertissements et les réactive après exécution de ton sql.

  3. #3
    Membre confirmé
    Inscrit en
    Avril 2008
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 129
    Par défaut
    Merci pour votre aide. Je ne comprends pas en quoi la création d'un clé primaire pourra m'aider, le problème ne sera-t-il pas toujours le même?

  4. #4
    Membre chevronné
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    427
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 427
    Par défaut
    Une clé primaire assure l'unicité d'un enregistrement.

    Si tu composes ta clé comme indiqué dans mon premier post, l'ajout sera rendu mécaniquement impossible pour tout enregistrement déja existant.

    Pour précision, il ne s'agit pas d'une clé primaire access automatique qui n'est qu'un autonum, mais d'une "vraie" clé composée.

Discussions similaires

  1. [AC-2013] Problème requête ajout/select en VBA
    Par Defaultuser01 dans le forum VBA Access
    Réponses: 11
    Dernier message: 24/05/2014, 03h55
  2. [Toutes versions] Problème avec une requête ajout
    Par Mat08 dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 22/12/2009, 14h00
  3. problème sur requête ajout
    Par yoruichi93 dans le forum Access
    Réponses: 7
    Dernier message: 10/05/2006, 14h51
  4. Problème avec requête ajout
    Par teffal dans le forum Access
    Réponses: 3
    Dernier message: 29/04/2006, 16h41
  5. Problème avec requête ajout
    Par mitnick32 dans le forum Access
    Réponses: 1
    Dernier message: 02/02/2006, 18h02

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