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

Langage SQL Discussion :

[Sql server] Récupérer max(date) par rapport a un numéro


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 89
    Par défaut [Sql server] Récupérer max(date) par rapport a un numéro
    Bonjour à tous,

    J'espère que vous allez pouvoir m'éclairer sur ma requete.

    Ma table se compose ainsi :
    - num_commande, NomClient, dimension, dateclient

    Le numéro de commande n'est pas unique, c'est à dire qu'il y a plusieurs ligne avec le même numéro de commande mais le champ dateclient varie selon la ligne.

    Je voudrai récupéré les informations d'un num_commande qui a le max(dateclient) > 13/07/07 et < 16/07/07

    En gros , je voudrais :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "select num_cmd,NomClient,Dimension,dateclient from DWS_PctOrders where Max(dtclient) >='" & datejour & "' AND Max(dtclient) <='" & datefinprog & "'"
    J'espere que vous avez une solution pour ce problème. je vais continuer de mon coté , je vous tiendrez au courant.

    Merci d'avance à vous !

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 136
    Par défaut
    Quelque chose dans ce goût-là ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    SELECT  num_cmd
        ,   nomclient
        ,   dimension
        ,   dateclient 
    FROM    dws_pctorders   AS a 
    WHERE   EXISTS
            (   SELECT  1
                FROM    dws_pctorders   AS b
                WHERE   a.num_cmd = b.num_cmd
                HAVING  MAX(b.dateclient) BETWEEN :datejour AND :datefinprog
                    AND MAX(b.dateclient)   = a.dateclient
            )
    ;
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 89
    Par défaut
    La requete fonctionne apparemment, malheuresement j'ai toujours le message d'erreur : "Expiration du délai d'attente"...

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 136
    Par défaut
    Citation Envoyé par t1marlartiste
    La requete fonctionne apparemment, malheuresement j'ai toujours le message d'erreur : "Expiration du délai d'attente"...
    C'est un problème de l'application, plus de SQL.
    Alors ?
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 89
    Par défaut
    Non du tout, puisque ca ne marche pas . J'ai déja eu des requetes beaucoup plus longue qui fonctionnait.

    Tu n'aurais pas une solution, quitte à faire deux requètes et récupérer les données de la premiere dans un tableau et les comparer dans la deuxième requete?

  6. #6
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 136
    Par défaut
    Tu peux faire comme ça aussi :
    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  num_cmd
        ,   nomclient
        ,   dimension
        ,   dateclient 
    FROM    dws_pctorders   AS a
        INNER JOIN 
            (   SELECT  b.num_cmd
                    ,   MAX(b.dateclient)   AS max_date
                FROM    dws_pctorders   AS b
                GROUP BY b.num_cmd
                HAVING  MAX(b.dateclient) BETWEEN :datejour AND :datefinprog
            )   AS c
            ON  a.dateclient = c.max_date
            AND a.num_cmd = c.num_cmd
    ;
    Je ne pense pas que ce soit plus performant
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

Discussions similaires

  1. Réponses: 1
    Dernier message: 23/11/2007, 14h11
  2. [sql server] requête sur dates et heures (format du résultat
    Par isachat666 dans le forum Langage SQL
    Réponses: 1
    Dernier message: 21/02/2006, 13h48
  3. [sql server] format de date
    Par you98 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 25/10/2005, 10h02
  4. SQL SERVER 2000 -Format date
    Par Billouze dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 04/10/2005, 10h51
  5. [C#] [SQL Server] Récupérer la liste des bases d'un serveur.
    Par exe dans le forum Accès aux données
    Réponses: 2
    Dernier message: 05/08/2004, 17h40

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