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 :

incrémentation en vba


Sujet :

VBA Access

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5
    Par défaut incrémentation en vba
    bonjour
    sur une base access j'ai besoin d'incrémenter une clé primaire dans un formulaire
    j'ai fait une recherche sur ce forum et j'ai trouvé ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =(MaxDom("Personne";"Réf personne"))+1
    que j'ai mis dans la propriété valeur par défaut du champ
    mais j'ai le message #Erreur quand je veux ajouter un nouvel enregistrement
    si quelqu'un a une idée

  2. #2
    Rédacteur/Modérateur

    Avatar de Heureux-oli
    Homme Profil pro
    Contrôleur d'industrie
    Inscrit en
    Février 2006
    Messages
    21 086
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur d'industrie
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 21 086
    Par défaut
    Bonjour et bienvenue sur le Forum Access de DVP.
    Malheureusement, directement dans la valeur par défaut, ça ne marche pas.

    Par contre, si tu fais une fonction, tu peux récupérer la valeur de la fonction en valeur par défaut.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Public Function PersonnePlusUn()
    PersonnePlusUn = (MaxDom("Personne";"Réf personne"))+1
    End Function
    Dans la valeur par défaut, il suffit de mettre =PersonnePlusUn()
    J'ai pas encore de décodeur, alors, postez en clair ! Comment mettre une balise de code ?
    Débutez en VBA

    Mes articles


    Dans un MP, vous pouvez me dire que je suis beau, ... mais si c'est une question technique je ne la lis pas ! Vous êtes prévenus !

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5
    Par défaut
    merci mais sa ne fonctionne pas ...
    avec la ligne suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    PersonnePlusUn = (MaxDom("Personne";"Réf personne"))+1
    j'ai erreur de compilation et le ; est surligné

    j'ai remplacé le ; par une , et ensuite il ne reconnait pas MaxDom comme commande

    a mon avis le générateur d'expression n'est pas du vba
    donc il n'est pas reconnu par visual basic
    est ce que quelqu'un sait le faire en vba ??

  4. #4
    Membre Expert
    Avatar de mout1234
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    2 210
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 2 210
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Public Function PersonnePlusUn()
    PersonnePlusUn = (DMax("Personne","Réf personne"))+1
    End Function
    Je me permets d'ajuster ta réponse Heureux-oli, tu as oublié de transcrire en syntaxe VBA ...

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5
    Par défaut
    merci mout1234
    mais Maxdom n'est pas du vba
    j'ai mis ce code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Public Function PersonnePlusUn()
    PersonnePlusUn = (DMax("Réf personne", "Personne")) + 1
    End Function
    je n'ai pas d'erreur mais rien ne s'affiche

  6. #6
    Membre Expert
    Avatar de mout1234
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    2 210
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 2 210
    Par défaut
    Au vu des noms je suppose que Personne est le nom de la table...

    Ca ne serait pas plutot
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Public Function PersonnePlusUn()
    PersonnePlusUn = (DMax("Réf Personne", "Personne")) + 1
    End Function

  7. #7
    Membre Expert Avatar de Renardo
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 648
    Détails du profil
    Informations personnelles :
    Âge : 62
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 648
    Par défaut
    Il faut metre se code sur le generateur de code et non sur le generateur d'expression
    tu peux essayer sur :ApresMAJ sur entrer et aussi sorti, tu choisi celui qui te convien le mieu

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

Discussions similaires

  1. Incrément date VBA
    Par CedBlandam dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 04/10/2014, 14h22
  2. [VBA-E] Auto incrémentation en VBA dans Excel
    Par gantec dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 13/02/2007, 13h00
  3. [VBA-E] Calcul avec incrémentation
    Par dahu29 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 06/03/2006, 09h36
  4. [VBA-E] incrémentation inversée
    Par Squelet dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 28/02/2006, 14h20
  5. Réponses: 19
    Dernier message: 04/12/2005, 18h45

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