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 :

Fonction DSUM dans un recordset


Sujet :

VBA Access

  1. #1
    Membre actif
    Inscrit en
    Juillet 2007
    Messages
    411
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 411
    Points : 239
    Points
    239
    Par défaut Fonction DSUM dans un recordset
    bonjour à tous,
    j'ai fais une procédure qui doit générer des codes articles en passant par un recordset. Mais il se fait que je connaisse un blocage. Voici la procédure:
    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
    Public Sub ecriture()
    Dim NumCode As String
    Dim db As Database
    Dim rst As Recordset
    Set db = CurrentDb
    Set rst = db.OpenRecordset("ZArticle")
    NumCode = Val(rst.Fields("CodArt"))
    Do While Not rst.EOF
        Debug.Print rst.Fields("CodArt"), rst.Fields("Article")
        Debug.Print NumCode
        If NumCode > 0 Then Else NumCode = DMax("NumCode", "rst") + 1
        rst.Fields("Codart") = rst.Fields("CodeCat") & rst.Fields("CodeCL") & NumCode
        Debug.Print rst.Fields("CodArt")
        rst.MoveNext
        'rst.RecordCount
    Loop
    MsgBox "Il y a eu au total" & rst.RecordCount
    'MsgBox "Le traitement est terminé"
    End Sub
    Quand je l'exécute, voici la ligne qui est surlignée
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    NumCode = DMax("NumCode", "rst") + 1
    et voici le message d'erreur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    3078         Le moteur de base de données Microsoft Jet ne peut pas trouver la table ou la requête source 'rst'. Assurez-vous qu'elle existe et qu'elle est correctement orthographiée.
    quelqu'un pourrait me dire pouquoi ceci ne marche pas?
    merci

  2. #2
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Février 2006
    Messages : 21 087
    Points : 42 926
    Points
    42 926
    Par défaut
    Salut,

    Je pense pas que l'on puisse appliquer un fonction Dmax sur un recordset.
    Essaie de le faire sur une requête.

  3. #3
    Invité
    Invité(e)
    Par défaut
    Bonjour

    Je plussoies ce que dit Heureux-oli .

    Les fonctions de domaines ne peuvent travailler que sur des tables ou des requêtes qui sont présentes dans ta base.

    Comme ton recordset est pris sur ZArticle, je te conseille de remplacer rst par ce nom.

    Philippe

  4. #4
    Membre actif
    Inscrit en
    Juillet 2007
    Messages
    411
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 411
    Points : 239
    Points
    239
    Par défaut
    merci à tous les deux,

    a dit Philippe JOCHMANS

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Comme ton recordset est pris sur ZArticle, je te conseille de remplacer rst par ce nom.
    je l'avais déjà fais, pas de connection.

    a dit Heureux-oli

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Essaie de le faire sur une requête.
    je vais tenter de faire ça. Mais je présume que dans une requête les données seront traitées par lot et non pas enregistrement par enregistrement. la difficulté risque de rester intacte. Je tente tout de même quelque chose et je vous dis quoi.

    mecri

  5. #5
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Février 2006
    Messages : 21 087
    Points : 42 926
    Points
    42 926
    Par défaut
    Salut,

    Mais de toute façon, comme tu utilises la fonction pour chaque enregistrement du recordset, tu auras une nouvelle valeur à chaque utilisation.

Discussions similaires

  1. [AC-2007] Fonction DSum dans une requête
    Par jmde dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 31/03/2015, 02h08
  2. Fonctions usuelles dans recordset
    Par jazzybluesy dans le forum VBA Access
    Réponses: 2
    Dernier message: 31/10/2012, 10h31
  3. [AC-2007] Problème fonction SEEK dans un RECORDSET
    Par FtF Nemesis dans le forum VBA Access
    Réponses: 1
    Dernier message: 28/04/2011, 17h18
  4. [VB6] Sauvegarder la position dans un Recordset
    Par inotna2099 dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 29/04/2003, 17h35
  5. [VBA-E] Fonction sum() dans une cellule
    Par Gonzo dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 16/12/2002, 10h18

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