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 :

Requête SELECT


Sujet :

Langage SQL

  1. #1
    Membre à l'essai
    Homme Profil pro
    Développeur Web
    Inscrit en
    Décembre 2008
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Décembre 2008
    Messages : 17
    Points : 13
    Points
    13
    Par défaut Requête SELECT
    * Bonjour, *

    J'ai une table contient 3 attributs (idFichier, nomFichier, dateFichier):
    je veux faire une sélection du nomFichier WHERE dateFichier est le dernier mais j'ai pas trouvé.

    Par exemple j'ai ces deux lignes:
    1 | fichie1 | 01/09/2011
    2 | fichie2 | 11/11/2011
    après l'exécution de la requête il m'affiche "fichie2".

    * Merci *

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 239
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 239
    Points : 12 870
    Points
    12 870
    Par défaut
    Bonjour,
    Tu as plusieurs possibilités:
    1. avec un MAX et une sous-requête: tu cherches les fichiers dont la date est la date MAX()
    2. avec une jointure externe ou un EXISTS: tu cherches les fichiers pour lesquels il n'existe pas d'autre fichier avec une date supérieure
    3. je ne sais pas, mais il y a surement une troisième possibilité !

    Tatayo.

  3. #3
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 048
    Points
    34 048
    Billets dans le blog
    14
    Par défaut
    Pas dur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT nomFichier
    FROM la_table
    WHERE dateFichier = 
    (
      SELECT MAX(dateFichier)
      FROM la_table
    )

  4. #4
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    Citation Envoyé par tatayo Voir le message
    3. je ne sais pas, mais il y a surement une troisième possibilité !

    Tatayo.
    Les fonctions de fenêtrages

  5. #5
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Points : 13 314
    Points
    13 314
    Par défaut
    Citation Envoyé par wass878 Voir le message
    J'ai une table contient 3 attributs (idFichier, nomFichier, dateFichier):
    je veux faire une séléction du nomFichier where dateFichier est le dernier mais j'ai pas trouvé.

    Par exemple j'ai ces deux lignes:
    1 | fichie1 | 01/09/2011
    2 | fichie2 | 11/11/2011
    aprés l'exécution de la requête il m'affiche "fichie2".
    Si j'ai bien compris , vous souhaitez quelque chose comme cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    select NOMFICHIER, DATEFICHIER
                from
                  (
                    select NOMFICHIER, DATEFICHIER,            
                            ROW_NUMBER() over(order by DATEFICHIER desc) DateRowNum
                      from theTable        
     
                    )
                where DateRowNum = 1;

  6. #6
    Membre émérite Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Points : 2 845
    Points
    2 845
    Par défaut
    Salut,

    Si on veut garder les ex-aequo comme dans la requête de Cinephile, utiliser dense_rank() à la place de row_number().

    Sinon pour faire sale et fun (version ne renvoyant qu'une seule ligne par contre), tu peux faire chercher le max de la concaténation de la date au format YYYYMMDD et du fichier, puis prendre la sous chaîne à partir du 9ème caractère .

    Sous Oracle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    select substr(max(to_char(datefichier, 'yyyymmdd') || nomfichier), 9)
    from tatable

Discussions similaires

  1. Résultat commençant par un chiffre avec requête SELECT
    Par nicolas.pissard dans le forum Requêtes
    Réponses: 4
    Dernier message: 02/04/2010, 13h31
  2. C'est possible dans une requête SELECT ?
    Par Kokito dans le forum Langage SQL
    Réponses: 7
    Dernier message: 15/04/2005, 16h59
  3. Insertion multiple à base de sous requête SELECT
    Par drinkmilk dans le forum Langage SQL
    Réponses: 8
    Dernier message: 14/04/2005, 16h34
  4. SQL Server 7.0 - Requête Select
    Par sangokus dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 23/03/2004, 10h32
  5. Optimisations mysql sur les requêtes SELECT: index
    Par leo'z dans le forum Débuter
    Réponses: 2
    Dernier message: 29/11/2003, 13h23

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