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

Requêtes et SQL. Discussion :

Intégrer dans une requete une fonction de récupération de date [AC-2010]


Sujet :

Requêtes et SQL.

  1. #1
    Membre actif
    Inscrit en
    Janvier 2003
    Messages
    604
    Détails du profil
    Informations forums :
    Inscription : Janvier 2003
    Messages : 604
    Points : 247
    Points
    247
    Par défaut Intégrer dans une requete une fonction de récupération de date
    Bonjour,
    Je voudrais dans la mise à jour d'un champs, permettre d'extraire une date d'un champs pour venir le concatener à d'autres données dans un autre champs.
    Voilà ce que j'ai écris après plusieurs tentatives infructueuses.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Call MAJ_QUARTER("DataBase")
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Sub MAJ_QUARTER(table As String)
    requeteQ1_A_N = "UPDATE " & table & " set quarter = '" & "FY" & Donne_Annee(table) & "Q1';"
    DoCmd.RunSQL requeteQ1_A_N
    end sub
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Function Donne_Annee(BDD As String) As String
    Dim lannee As Integer
    lannee = Year(BDD.[Coverage End Date])
    Donne_Annee = lannee
    End Function
    Merci d'avance de vos idées.

  2. #2
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 365
    Points : 23 835
    Points
    23 835
    Par défaut
    Bonjour.

    Pour récupérer l'année

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Function Donne_Annee(BDD As String) As String
       Dim lannee As Integer
       lannee = Year(DFirst("[Coverage End Date]", bdd)
       Donne_Annee = lannee
    End Function
    mais comme tu passes un nom de table je te suggère

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Function Donne_Annee(nomtable As String) As long
       Dim lannee As Integer
       lannee = Year(DFirst("[Coverage End Date]", nomTable)
       Donne_Annee = lannee
    End Function
    et

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sub MAJ_QUARTER(nomTable As String)
    Le reste devrait fonctionné.

    A+

  3. #3
    Membre actif
    Inscrit en
    Janvier 2003
    Messages
    604
    Détails du profil
    Informations forums :
    Inscription : Janvier 2003
    Messages : 604
    Points : 247
    Points
    247
    Par défaut
    Merci, je test cela Lundi. Bon week-end.

  4. #4
    Membre actif
    Inscrit en
    Janvier 2003
    Messages
    604
    Détails du profil
    Informations forums :
    Inscription : Janvier 2003
    Messages : 604
    Points : 247
    Points
    247
    Par défaut
    Citation Envoyé par comme de bien entendu Voir le message
    Merci, je test cela Lundi. Bon week-end.
    Non finalement cela ne marche pas, il faut tenir compte du fais que je cherche à récupérer l'année du champs [Coverage End date] sur le upplet selectionné pour faire le update du champs [QUARTER];

    voici une autre de mes tentatives :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    requeteQ1_A_N = "UPDATE " & table & " SET QUARTER = '" & "FY" & Right(Chr(34) & table & Chr(34) & .[Coverage End Date], 4) & Chr(34) & "Q1'"
    Merci d'avance de vos idées.

  5. #5
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 365
    Points : 23 835
    Points
    23 835
    Par défaut
    Bonjour.

    Peux-tu poster la structure de la table "table" ? Ça aiderai à trouver la bonne syntaxe.

    Sinon, tu peux aussi faire la requête avec l'éditeur de requête de Access puis changer l'affichage pour SQL.
    Généralement il est ensuite assez facile de transformer le SQL généré par Access pour l'utiliser dans VBA.

    A+

  6. #6
    Membre actif
    Inscrit en
    Janvier 2003
    Messages
    604
    Détails du profil
    Informations forums :
    Inscription : Janvier 2003
    Messages : 604
    Points : 247
    Points
    247
    Par défaut
    Bonsoir,
    Finalement j'ai testé en utilisant le mode requête Sql d'Access. C'est beaucoup plus simple pour comprendre les bugs de positionnement des simple et double guillemets. Je fais un debug.print que je recopie plus facilement dans Access. J'essayerai de copier la version qui marche cela requête demain pour clore le sujet.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 20/08/2009, 03h22
  2. Réponses: 1
    Dernier message: 27/01/2009, 11h46
  3. Réponses: 5
    Dernier message: 25/01/2008, 11h15
  4. [MySQL] afficher une requete en fonction de résultats d'autres requetes
    Par mayers dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 27/07/2007, 10h42
  5. Réponses: 7
    Dernier message: 19/05/2007, 13h11

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