Précédent   Forum des professionnels en informatique > Bases de données > Oracle
Oracle Forum Oracle : le serveur, les outils, ... Voir F.A.Q Oracle Tutoriels Oracle
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 17/12/2007, 11h46   #1
Invité de passage
 
Inscription : avril 2006
Messages : 6
Détails du profil
Informations forums :
Inscription : avril 2006
Messages : 6
Points : 2
Points : 2
Par défaut Sysdate sans les heures

Bonjour,
je souhaite faire une requête sql en sélectionnant tous mes enregistrements dont la date est comprise entre la date d'aujourd'hui et la fin du mois.
Mon problème est que lorsque j'utilise la fonction sysdate, cela me donne un format de date jj/mm/aaaa HH:mm:ss, et je voudrais seulement jj/mm/aaaa pour que mes sélections fonctionnent correctement.
Quelqu'un pourrait-il m'aider ?
Merci
leroysomer est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 17/12/2007, 11h52   #2
Rédacteur/Modérateur
 
Avatar de orafrance
 
Inscription : janvier 2004
Messages : 15 861
Détails du profil
Informations personnelles :
Âge : 35

Informations forums :
Inscription : janvier 2004
Messages : 15 861
Points : 16 212
Points : 16 212
tu peux utiliser TRUNC mais le mieux c'est encore de tenir compte de ces heures.

Code :
TRUNC(colonne) = TRUNC(SYSDATE)
devient :

Code :
colonne BETWEEN TRUNC(SYSDATE) AND TRUNC(SYSDATE + 1)
Ainsi tu conserves l'usage des indexes
orafrance est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 17/12/2007, 13h16   #3
Invité de passage
 
Inscription : avril 2006
Messages : 6
Détails du profil
Informations forums :
Inscription : avril 2006
Messages : 6
Points : 2
Points : 2
Par défaut Merci

Génial ! ça fonctionne !!
Je dois ne pas tenir compte des heures, sinon selon l'heure à laquelle les utilisateurs le rafraichissent ils n'ont pas la journée en cours...
En tout cas, la fonction trunc me va très bien.
A++
leroysomer est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 17/12/2007, 14h04   #4
McM
Expert Confirmé Sénior
 
Inscription : juillet 2003
Messages : 3 453
Détails du profil
Informations forums :
Inscription : juillet 2003
Messages : 3 453
Points : 4 217
Points : 4 217
Houla, je ne suis pas d'accord :
Code :
1
2
3
TRUNC(colonne) = TRUNC(SYSDATE)
DIFFERENT DE
colonne BETWEEN TRUNC(SYSDATE) AND TRUNC(SYSDATE + 1)
Pb si colonne = trunc(sysdate) + 1
Il faut faire
Code :
1
2
colonne >= TRUNC(SYSDATE) 
AND colonne < TRUNC(SYSDATE + 1)
__________________
More Code : More Bugs. Less Code : Less Bugs
McM est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 17/12/2007, 14h12   #5
Rédacteur/Modérateur
 
Avatar de orafrance
 
Inscription : janvier 2004
Messages : 15 861
Détails du profil
Informations personnelles :
Âge : 35

Informations forums :
Inscription : janvier 2004
Messages : 15 861
Points : 16 212
Points : 16 212
en effet, le BETWEEN prend les bornes en compte, au temps pour moi
orafrance est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/12/2007, 15h11   #6
Membre régulier
 
Avatar de hugobob
 
Inscription : septembre 2005
Messages : 138
Détails du profil
Informations forums :
Inscription : septembre 2005
Messages : 138
Points : 79
Points : 79
Envoyer un message via MSN à hugobob Envoyer un message via Yahoo à hugobob
peut-on aussi utiliser to_char en formatant les dates ?
hugobob est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/12/2007, 18h05   #7
Expert Confirmé
 
Avatar de LeoAnderson
 
Inscription : septembre 2004
Messages : 2 942
Détails du profil
Informations forums :
Inscription : septembre 2004
Messages : 2 942
Points : 2 972
Points : 2 972
non, on perdrait l'usage des indexes (sauf index basé sur des fonctions)
LeoAnderson est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/12/2007, 19h28   #8
Invité de passage
 
Inscription : avril 2006
Messages : 6
Détails du profil
Informations forums :
Inscription : avril 2006
Messages : 6
Points : 2
Points : 2
Ok, j'ai rectifié !
Merci à tous...
leroysomer est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 13h27.


 
 
 
 
Partenaires

Hébergement Web