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

SQL Firebird Discussion :

DateAdd et février


Sujet :

SQL Firebird

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Homme Profil pro
    Directeur technique
    Inscrit en
    Mai 2008
    Messages
    2 400
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2008
    Messages : 2 400
    Par défaut DateAdd et février
    Salut !
    dans un de mes codes je me suis aperçu que DateAdd ne donne aucun résultat quand je lui passe comme argument le mois de février.

    pour pouvoir me suivre je mets le bout de code en question :

    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
    37
    38
    39
    40
    41
    42
    43
    44
    45
    BEGIN
    FOR
         select
            d.code_unite,
            d.nom_unite,
     
            sum( c.frais_total ) frais_total,
     
            sum( a.montant_facture  ) montant_facture,
            sum( ( e.volume_mj_sortie ) * ( e.nombre_jour_reel ) ) volume_mj_sortie,
     
            /* calcul du ratio d'épuration */
            (
                 (  sum( c.frais_total  )   +  sum( a.montant_facture  )  ) /
                 ( sum( ( e.volume_mj_sortie ) * ( e.nombre_jour_reel ) ) )
            ) ratio
     
        from tb_energie a
            inner join tb_step b on ( a.code_step = b.code_step )
            inner join tb_frais_exploitations c on ( b.code_step = c.code_step )
                    and ( c.date_mois between :date_debut and :date_fin )
            inner join tb_unite d on ( b.code_unite = d.code_unite )
            inner join tb_process e on ( b.code_step = e.code_step )
                    and ( e.date_bilan between :date_debut and :date_fin )
     
        where
            (
                a.date_mois between dateadd(month, -1, :date_debut) and dateadd(month, -1, :date_fin)
            )
     
        group by d.code_unite, d.nom_unite
     
        into
                :CODE_UNITE,
                :NOM_UNITE,
                :FRAIS_TOTAL,
                :MONTANT_FACTURE,
                :VOLUME_MJ_SORTIE,
                :RATIO_EXP_EAU_EPUREE
     
    do
    begin
      suspend;
      end
    end
    Pour tout les mois j'ai le bon résultat mais quand je passe le mois de février en argument j'ai un tableau vide !!! s'agit'il d'un bug ?

  2. #2
    Expert confirmé
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Par défaut
    Salut

    :DATE_DEBUT et :DATE_FIN sont bien des TIMESTAMP ?

    Parce que ceci me renvoie un résultat correct:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT DATEADD(MONTH, -1, CAST('2012-02-29' AS TIMESTAMP)) FROM RDB$DATABASE
    soit le 29 janv. 2012.



    @+ Claudius

  3. #3
    Membre Expert
    Homme Profil pro
    Directeur technique
    Inscrit en
    Mai 2008
    Messages
    2 400
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2008
    Messages : 2 400
    Par défaut
    Citation Envoyé par Cl@udius Voir le message
    Salut

    :DATE_DEBUT et :DATE_FIN sont bien des TIMESTAMP ?

    Parce que ceci me renvoie un résultat correct:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT DATEADD(MONTH, -1, CAST('2012-02-29' AS TIMESTAMP)) FROM RDB$DATABASE
    soit le 29 janv. 2012.



    @+ Claudius
    Merci pour la réponse mon ami.
    à vrai dire c'était des date, je viens de les changer en TimesTamp mais toujours rien !!!! pourtant mes tables sont bien renseignées !!!

  4. #4
    Expert confirmé
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Par défaut
    Citation Envoyé par Just-Soft Voir le message
    à vrai dire c'était des date, ...
    Oui quand je disais TIMESTAMP, il peut également s'agir de DATE ou DATETIME.
    Je voulais juste m'assurer que tu manipulais bien une date.

    Sinon je ne vois pas. Et quand tu debug ta procédure, ça donne quoi ?

  5. #5
    Membre Expert
    Homme Profil pro
    Directeur technique
    Inscrit en
    Mai 2008
    Messages
    2 400
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2008
    Messages : 2 400
    Par défaut
    Citation Envoyé par Cl@udius Voir le message
    Oui quand je disais TIMESTAMP, il peut également s'agir de DATE ou DATETIME.
    Je voulais juste m'assurer que tu manipulais bien une date.

    Sinon je ne vois pas. Et quand tu debug ta procédure, ça donne quoi ?
    ça donne rien et c'est ce qui m'intrigue !
    j'ai une ligne vide mais aucune erreur

  6. #6
    Expert confirmé
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Par défaut
    Alors a priori rien voir avec DateAdd, mais plutôt un jeu de données qui est bancal pour ce mois (cf les INNER JOIN avec les BETWEEN).

    Découpe ta requête 'en petits morceaux' pour voir ce que cela donne.

Discussions similaires

  1. fonction DATEADD [SQL SERVER]
    Par HULK dans le forum Langage SQL
    Réponses: 4
    Dernier message: 28/12/2004, 17h33
  2. Dateadd ????
    Par fdloisel dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 26/10/2004, 08h28
  3. FONCTIONS GETDATE DATEADD DATEDIFF : URGENT
    Par fleuve007 dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 11/02/2004, 10h35
  4. Pb de date: 28 ou 29 février?
    Par kayser dans le forum ASP
    Réponses: 5
    Dernier message: 03/12/2003, 09h14

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