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 MySQL Discussion :

Récupérer une valeur d'un champ précédent


Sujet :

Requêtes MySQL

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Août 2009
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2009
    Messages : 5
    Points : 5
    Points
    5
    Par défaut Récupérer une valeur d'un champ précédent
    Bonjour,
    Je m'excuse par avance pour les possibles erreurs que je risque de faire.

    J'ai 2 tables :
    Compte(IDCompte, DateCreation)
    et ProlongationCompte (IDProlongationCompte,IDCompte,DateProlongation,Duree)

    Je cherche a récupérer un tableau de toutes les prolongations effectuées sur un compte.

    J'ai une date de début(Date de création) et une durée enregistrées dans ma base mySql.

    Dans mon tableau :
    - le premier enregistrement : vous me direz rien de compliqué Date de prolongation + durée = Date de fin

    - Mais ensuite pour le second enregistrement il faut que cette date de fin devienne la date de début et que la nouvelle durée rentrée par l'utilisateur s'ajoute à cette même date de début pour créer la date de fin

    etc etc ... pour les autres enregistrements.

    Et je suis totalement perdue. J'ai bien essayé des DATE_ADD, SUM, MAX mais rien de concluant (s'il n'y a qu'un enregistrement je sais le récupérer mais s'il y en a 2, cela me modifie le premier)

    Je vous remercie par avance de votre aide

  2. #2
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 034
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 034
    Points : 23 779
    Points
    23 779
    Par défaut
    Bonjour,

    Je ne suis pas certain de bien saisir tout le problème.
    Je pense qu'un petit exemple nous permettrait de mieux comprendre.

    Par exemple, est-ce que les prolongations d'un même compte se suivent dans le temps de manière juxtaposée (c'est-à-dire que 2 prolongations successives se font sans intervalle de temps entre les 2) ?

    Si c'est le cas, c'est faisable en une requête, mais elle est compliquée et risque d'avoir des performances rapidement très dégradées.

    J'arrive à quelque chose comme ça :
    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
    select IDCompte, IDProlongationCompte, DateDebut, sumDuree, Date_add(DateDebut, interval sumDuree DAY) as DateFin
    from (
      select IDCompte, IDProlongationCompte
      , (select min(pc2.DateProlongation)
         from ProlongationCompte pc2
         where pc2.DateProlongation <= pc.DateProlongation
      ) as DateDebut
      , Duree
      , (select sum(Duree)
         from ProlongationCompte pc2
         where pc2.DateProlongation <= pc.DateProlongation
      ) as sumDuree
      from ProlongationCompte pc
    ) as t
    order by IDCompte, IDProlongationCompte

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Août 2009
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2009
    Messages : 5
    Points : 5
    Points
    5
    Par défaut Suite
    Excusez moi, j'ai du mal m'exprimer.

    La date de prolongation est la date de création de la prolongation, elle ne sert donc pas a calculer une date de début.

    Un petit exemple pour éclairer votre chemin :
    J'ai un compte qui a une durée de vie de 2 h.
    je crée mon compte le 09/03/2010 à 8h00, il devra être inactif donc le 09/03/2010 à 10h00.

    Mais je veux prolonger la durée de vie de ce compte de 1h => sa durée de début est donc le 09/03/2010 à 10h00 et sa date de fin le 09/03/2010 à 11h00.

    Pour simplement le premier enregistrement j'ai fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT IDCompte
            ,IDCompteProlongation
            ,DATE_ADD(DateCreationCompte ,INTERVAL DureeCompte DAY_HOUR) AS DateDebut
            ,DATE_ADD(DATE_ADD(DateCreationCompte 
                           ,INTERVAL DureeCompte DAY_HOUR) 
             ,INTERVAL DureeProlongation) AS DateFin
    FROM CompteProlongation
    INNER JOIN Compte ON Compte.IDCompte = CompteProlongation.IDCompte
    ce qui donne ma date de début et ma date de fin de ma prolongation 1.

    Pour le second enregistrement j'ai du mal car la date de fin de ma prolongation 1 devra devenir ma date de début 2 et ma date de fin 2 = Date de début 2 + nouvelle durée

    Pour le troisième etc ....

    et je dois récupérer bien entendu tous les résultats avec la même requête.

    j'espère que vous avez mieux compris et que vous pourrez m'aider
    Merci

  4. #4
    Membre expert
    Avatar de Maljuna Kris
    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2005
    Messages
    2 613
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 613
    Points : 3 950
    Points
    3 950
    Par défaut
    Saluton,
    Pour avoir la date de fin d'une prolongation il faut ajouter à la date de création du compte la somme des durées de prolongation de date antérieures ou égale à la date de la prolongation en cours de traitement et la durée initiale du contrat.
    On doit pouvoir faire ça avec une autojointure et un GROUP BY.

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Août 2009
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2009
    Messages : 5
    Points : 5
    Points
    5
    Par défaut
    Merci beaucoup à vous deux !!
    J'ai réussi à avoir ce que je voulais !!
    et cela donne ca :

    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
    SELECT IDCompteProlongation
             ,DateDebutPro
             ,IDCompte
             ,sumDuree
             ,DureeDebut
             ,DATE_ADD(DateDebutPro, INTERVAL sumDuree DAY_HOUR) AS DateFin
             ,DATE_ADD(DateDebutPro, INTERVAL DureeDebut DAY_HOUR) AS DateDebut
    FROM (
             SELECT IDCompte,IDCompteProlongation
               ,(SELECT DATE_ADD(DateCreation,INTERVAL Duree DAY_HOUR)
                 FROM Compte
                 WHERE IDCompte = idCompte ) AS DateDebutPro
               ,Duree
               ,(SELECT SUM(Duree)
                  FROM CompteProlongation pc2
                  WHERE pc2.DateProlongation <= pc.DateProlongation AND IDCompte = idCompte) AS sumDuree
               ,((SELECT SUM(Duree)
                  FROM CompteProlongation pc2
                   WHERE pc2.DateProlongation <= pc.DateProlongation AND IDCompte = idCompte) - (SELECT Duree
                                         FROM CompteProlongation pc2
                                         WHERE IDCompteProlongation IN(SELECT MAX(IDCompteProlongation)
                                                                                     FROM CompteProlongation pc2
                                                                                        GROUP BY IDCompte))) AS DureeDebut
             FROM CompteProlongation pc ) AS T
                       WHERE IDCompte =  idCompte;
    Merci encore de votre aide

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

Discussions similaires

  1. Récupérer une valeur d'un champ dans un contrôleur
    Par clubist dans le forum ASP.NET MVC
    Réponses: 2
    Dernier message: 27/06/2013, 13h25
  2. Réponses: 1
    Dernier message: 25/05/2011, 15h43
  3. Récupérer une valeur dans un champ
    Par nardoum dans le forum jQuery
    Réponses: 6
    Dernier message: 12/02/2011, 21h42
  4. Récupérer une valeur de la ligne précédente
    Par oOBaalberithOo dans le forum SQL
    Réponses: 2
    Dernier message: 05/06/2008, 09h27
  5. Récupérer une valeur dans un champ d'une autre table
    Par Kareg dans le forum Modélisation
    Réponses: 15
    Dernier message: 24/10/2007, 14h16

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