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

Filtrage d'une table par Date DD/MM/YY


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2015
    Messages : 2
    Par défaut Filtrage d'une table par Date DD/MM/YY
    Bonjours a vous,

    Je souhaiterais afficher tout les employés embauchés en 94.

    Voici ma ligne de commande m'affichant une erreur d'expression manquante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT last_name, hire_date FROM employees WHERE date =(hire_date, 'dd/mm/94');
    J'attend votre aide avec impatience,
    Bien cordialement.

  2. #2
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    Bonjour,

    Tu as 2 solutions :

    utiliser EXTRACT
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE EXTRACT(YEAR FROM hire_date) = 1994
    Plus rapide qu'un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TO_NUMBER(TO_CHAR(hire_date, 'YYYY')) = 1994
    Ou utiliser un troncage de la date (moins performant)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE TRUNC(hire_date, 'YYYY') = to_date('01/01/1994', 'DD/MM/YYYY')

  3. #3
    Nouveau candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2015
    Messages : 2
    Par défaut
    Merci beaucoup pour cette réponse rapide, claire et précise avec multi-option ^^.
    J'avais penser a extract mais mal rédiger.

    Encore merci =).

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    La solution optimale c'est celle-ci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select last_name, hire_date
      from employees
     where hire_date >= date '1994-01-01'
       and hire_date <  date '1995-01-01';
    Pas de conversion de colonne, utilisation d'un éventuel index naturel.

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

Discussions similaires

  1. filtrage d'une table par date
    Par rafikjka dans le forum Bases de données
    Réponses: 6
    Dernier message: 03/05/2012, 09h40
  2. [MySQL] Afficher les données de plusieurs tables par date en une seule liste.
    Par Romanodi13 dans le forum PHP & Base de données
    Réponses: 22
    Dernier message: 08/09/2011, 21h45
  3. Réponses: 3
    Dernier message: 06/09/2010, 16h22
  4. Réponses: 1
    Dernier message: 22/10/2008, 18h08
  5. Extraire données d'une table par date
    Par Hombe dans le forum Langage SQL
    Réponses: 7
    Dernier message: 08/11/2006, 23h03

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