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 :

Sous-formulaire retourne 0 [AC-2016]


Sujet :

VBA Access

  1. #1
    Membre du Club
    Inscrit en
    Janvier 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 86
    Points : 46
    Points
    46
    Par défaut Sous-formulaire retourne 0
    Bonjour,

    J'ai un problème avec les sous-formulaires qui ne retournent pas le résultat souhaité. les sous-formulaires sont basés sur des requêtes conditionnelles. les requêtes retournent les résultats quand testées. Cependant les sous-formulaires retournent 0

    ma base de données est comme suit

    Nom : my_database.jpg
Affichages : 50
Taille : 166,1 Ko

    Les sous-formulaires sont insérés dans un formulaire principal qui prend la date (sélectionnée) depuis un autre formulaire (F_MENU)..

    je ne trouve pas l'erreur sur le code VBA du sous-formulaire (form_load()).

    voila le code VBA inclus au sous-formulaire :
    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
    35
    36
    Private Sub Form_Load()
     
    Dim accessRS As Recordset
    Dim strq3 As String
    Dim db As Database
    Dim mydate As Date
    Set db = CurrentDb
     
    mydate = [Forms]![F_MENU]![s_date]
     
    strq3 = "select datemvt, CIMAF, MIRA, FAKOTRANS, OKPLAST, TOTAL_ENTREE from sR_clinkerE where datemvt=#" & Format(mydate, "dd/mm/yyyy") & "# ;"
     
    Set accessRS = db.OpenRecordset(strq3)
     
    If accessRS.RecordCount > 0 Then
     
    Me.cimaf_clnk = IIf(Nz(accessRS![CIMAF], 0) = 0, 0, accessRS![CIMAF])
    Me.mira_clnk = IIf(Nz(accessRS![MIRA], 0) = 0, 0, accessRS![MIRA])
    Me.FAKOTRANS_clnk = IIf(Nz(accessRS![FAKOTRANS], 0) = 0, 0, accessRS![FAKOTRANS])
    Me.okplast_clnk = IIf(Nz(accessRS![OKPLAST], 0) = 0, 0, accessRS![OKPLAST])
    Me.TOTAL_ENTREE_clnk = IIf(Nz(accessRS![TOTAL_ENTREE], 0) = 0, 0, accessRS![TOTAL_ENTREE])
     
    Else
     
    Me.cimaf_clnk = 0
    Me.mira_clnk = 0
    Me.FAKOTRANS_clnk = 0
    Me.okplast_clnk = 0
    Me.TOTAL_ENTREE_clnk = 0
     
    End If
     
    accessRS.Close
    Set accessRS = Nothing
     
    End Sub
    ce sous-formulaire est basée sur la requête conditionnelle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT type.Type AS TYPE, Mvmt.datemvt, Sum(IIf(Len([Mvmt]![qte1m])=0,"0",[Mvmt]![qte1m])) AS CIMAF, Sum(IIf(Len([Mvmt]![qte2m])=0,"0",[Mvmt]![qte2m])) AS MIRA, Sum(IIf(Len([Mvmt]![qte3m])=0,"0",[Mvmt]![qte3m])) AS FAKOTRANS, Sum(IIf(Len([Mvmt]![qte4m])=0,"0",[Mvmt]![qte4m])) AS OKPLAST, Sum([Mvmt].[qte1m]+[Mvmt].[qte2m]+[Mvmt].[qte3m]+[Mvmt].[qte4m]) AS TOTAL_ENTREE, Sum(Mvmt.qte5m) AS SEC, Sum(Mvmt.qte6m) AS MOUILLE, Sum(Mvmt.total_qte) AS TOTAL2
    FROM type INNER JOIN (typemvt INNER JOIN (Produit INNER JOIN Mvmt ON Produit.idtype = Mvmt.idtypefk) ON typemvt.idtypemvt = Mvmt.idtypemvtfk) ON type.idtype = Produit.idtype
    WHERE (((Produit.idtype)=1) AND ((typemvt.idtypemvt)=1) AND ((Mvmt.idtypefk)=[Produit]![idtype]) AND ((Mvmt.idtypemvtfk)=[typemvt]![idtypemvt]))
    GROUP BY type.Type, Mvmt.datemvt;
    Merci de trouver le temps de porter main

  2. #2
    Membre chevronné
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 380
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 380
    Points : 2 007
    Points
    2 007
    Par défaut
    Salut,

    Sauf erreur de ma part, le format de date n'est pas bon.
    Essaye mm/dd/yyyy#

  3. #3
    Membre du Club
    Inscrit en
    Janvier 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 86
    Points : 46
    Points
    46
    Par défaut Format de date SQL
    Bonjour,

    En effet, le format de date SQL est sujet de la question. J'ai essayé le format yyyy-mm-dd et ça a marché. Je crois que le format mm/dd/yyyy marche aussi

    Merci pour votre temps deedolith

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

Discussions similaires

  1. [AC-2010] Actualiser un sous formulaire sans retourner au premier enregistrement
    Par anouar_chaieb dans le forum VBA Access
    Réponses: 13
    Dernier message: 27/07/2022, 19h11
  2. Verouillage de formulaire et sous formulaire
    Par Mattdesoibs dans le forum IHM
    Réponses: 3
    Dernier message: 15/10/2004, 10h22
  3. Rafraichir un sous-formulaire
    Par estancha dans le forum IHM
    Réponses: 2
    Dernier message: 12/10/2004, 11h06
  4. Réponses: 2
    Dernier message: 10/10/2004, 23h12
  5. où est mon sous-formulaire ?
    Par yves_fuji dans le forum IHM
    Réponses: 2
    Dernier message: 08/09/2004, 08h34

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