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

SSIS Discussion :

[SSIS] [2K5] Retirer 7 jours à une date


Sujet :

SSIS

  1. #1
    Membre régulier Avatar de SebastienM
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    310
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 310
    Points : 86
    Points
    86
    Par défaut [SSIS] [2K5] Retirer 7 jours à une date
    Bonjour, je voudrais retirer 7 jours à une date : pour cela j'utilise un composant de type script (pas trouvé mieux), et j'ai appliqué le code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    Public Overrides Sub Input0_ProcessInputRow(ByVal Row As Input0Buffer)
            '
            ' Add your code here
            '
            Dim dateTemp As Date
            dateTemp = Row.DATELIVRAISONPREVUE
     
            dateTemp.AddDays(-7)
     
            MsgBox(Row.DATELIVRAISONPREVUE.ToString & " - " & dateTemp.ToString)
            Row.DATEJALONNEE = dateTemp
        End Sub
    Mais ça ne fonctionner pas ; sur ma msgbox j'ai les valeurs identiques.
    Auriez-vous une idée sur le pourquoi du comment ça ne fonctionne pas ?

    Merci d'avance !

  2. #2
    Membre éclairé
    Avatar de patriceharel
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Mai 2008
    Messages
    466
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2008
    Messages : 466
    Points : 884
    Points
    884
    Par défaut
    Bonjour,

    Pour retirer 7 jours à une colonne date et stocker le résultat dans une nouvelle colonne on peut utiliser un Derived Column, avec la méthode DateAdd paramétrée ainsi

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DateAdd ("day", -7, colonneDateATransformer)

  3. #3
    Membre du Club
    Profil pro
    Développeur informatique
    Inscrit en
    Mars 2003
    Messages
    93
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2003
    Messages : 93
    Points : 64
    Points
    64
    Par défaut
    Salut,
    tu devrais plutôt utiliser un composant "Colonne dérivée" avec la fonction dateadd
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DATEADD("d",-7,DATELIVRAISONPREVUE)
    Edit : Erff, t'as encore été plus rapide

  4. #4
    Membre éclairé
    Avatar de patriceharel
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Mai 2008
    Messages
    466
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2008
    Messages : 466
    Points : 884
    Points
    884
    Par défaut
    Citation Envoyé par skynet Voir le message
    Erff, t'as encore été plus rapide
    , j'ai pas de mérite, developpez.com c'est ma page d'accueil

  5. #5
    Membre régulier Avatar de SebastienM
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    310
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 310
    Points : 86
    Points
    86
    Par défaut
    Merci, c'est ce que je cherchais à faire à la base ; en revanche est-ce possible de remplacer le 7 par une variable, de tester si son existence est valide.

    Je m'explique, j'ai saisi ceci dans ma derived column :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    DATEADD("day",(-1 * DELTA),DATE_LIVRAISON_PREVUE)
    Maintenant, je voudrais tester si DELTA est nul, la remplacer par une constante '7'. Est-ce possible sans utiliser de conditionnal split ?

  6. #6
    Membre éclairé
    Avatar de patriceharel
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Mai 2008
    Messages
    466
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2008
    Messages : 466
    Points : 884
    Points
    884
    Par défaut
    Ça ça devrait passer

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DATEADD("day",(-1 * (ISNULL(DELTA)?-7:DELTA))),DATE_LIVRAISON_PREVUE)

  7. #7
    Membre régulier Avatar de SebastienM
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    310
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 310
    Points : 86
    Points
    86
    Par défaut
    Génial, je te remercie je ne savais pas qu'on pouvait tester une valeur dans un derived column ! ; il reste un bug qui vient de mon coté - je suppose que DELTA n'est ni un nombre entier, ni null à certains moments.
    En fait DELTA résulte d'une jointure (à droite sur une jointure externe gauche), et je ne sais pas ce qu'il renvoie lorsqu'il ne trouve pas la correspondance.

    Sur 38000 lignes j'en ai 224 qui ont la valeur calculée à NULL

  8. #8
    Membre éclairé
    Avatar de patriceharel
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Mai 2008
    Messages
    466
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2008
    Messages : 466
    Points : 884
    Points
    884
    Par défaut
    Sur un merge, si il n'y a pas de correspondance il y a Null il me semble.
    De même, si Delta n'est effectivement pas un nombre mais une string, il y a des risques que dans ta source de données la chaîne soit vide (taille=0 testable avec la fonction LEN(String)) et donc non nulle.

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

Discussions similaires

  1. Comment mettre à jour une date ?
    Par Hokagge dans le forum MFC
    Réponses: 6
    Dernier message: 22/03/2006, 12h30
  2. [MySQL] ajout de jour à une date
    Par mohican13 dans le forum Langage SQL
    Réponses: 5
    Dernier message: 06/03/2006, 17h39
  3. [VB]Enlever 1 jour à une date si heure est comprise entre...
    Par bb62 dans le forum VB 6 et antérieur
    Réponses: 17
    Dernier message: 20/01/2006, 14h48
  4. Réponses: 2
    Dernier message: 03/01/2006, 14h58
  5. [Dates] Soustraire un nombre de jour à une date
    Par lesgars dans le forum Langage
    Réponses: 2
    Dernier message: 09/12/2005, 14h43

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