Précédent   Forum des professionnels en informatique > Bases de données > MySQL > SQL Procédural
SQL Procédural Forum d'entraide sur les triggers, les procédures stockées et les fonctions en MySQL
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 31/12/2006, 23h05   #1
Futur Membre du Club
 
Inscription : décembre 2005
Messages : 75
Détails du profil
Informations forums :
Inscription : décembre 2005
Messages : 75
Points : 15
Points : 15
Par défaut Clause Where en fonction de la valeur d'un champs

Bonjour,

J'ai une table "events" avec les champs "date_start" et "date_end". Le champs "date_start" est toujours une date valide, alors que le champs "date_end" peut être NULL. En effet, certains events se produisent sur un seul jour alors que d'autres se produisent sur une période.

Je cherche la requête SQL qui extrait les events de la façon suivante:

- si "date_end" = NULL alors
Code :
WHERE date_start = date
- sinon ("date_end" est renseigné) alors
Code :
WHERE date_start => date <= date end
En d'autre termes, j'aimerais que mon SELECT renvoit les enregistrements selon ma clause WHERE qui dépend de la valeur de mon champs "date_end". Donc, pour chaque ligne il fat tester d'abord le champs "date_end" et en fonction du résultat la clause WHERE de la requête sera différente.

Comment faire cela en une seule requête?

Merci...
gb-ch est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/12/2006, 23h41   #2
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 540
Points : 9 540
Code :
WHERE  `date` BETWEEN  date_start AND COALESCE( date_end,  date_start)
attention à date qui est un mot réservé.
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 01/01/2007, 14h06   #3
Futur Membre du Club
 
Inscription : décembre 2005
Messages : 75
Détails du profil
Informations forums :
Inscription : décembre 2005
Messages : 75
Points : 15
Points : 15
Merci pour votre réponse, Antoun! Êtes-vous l'auteur du livre mentionné dans votre signature?

Citation:
Envoyé par Antoun
Code :
WHERE  `date` BETWEEN  date_start AND COALESCE( date_end,  date_start)
attention à date qui est un mot réservé.
Si je comprend bien cette requête, COALESCE va d'abord retourner 'date_end' s'il est NULL, sinon 'date_start' qui n'est jamais NULL.

Puis, si la valeur de 'date' est égale à 'date_end' alors l'expression 'BETWEEN date_start AND date_end' est toujours vraie.

Est-ce bien cela?

Autre question: si un champs date contient la valeur '0000-00-00' est-ce la même chose que la valeur NULL (et donc COALESCE reste utile dans ce cas)?

Encore merci...
gb-ch est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 01/01/2007, 15h45   #4
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 540
Points : 9 540
Citation:
Envoyé par gb-ch
Merci pour votre réponse, Antoun! Êtes-vous l'auteur du livre mentionné dans votre signature?
j'ai cet honneur
Citation:
Envoyé par gb-ch
Si je comprend bien cette requête, COALESCE va d'abord retourner 'date_end' s'il est NULL, sinon 'date_start' qui n'est jamais NULL.

Puis, si la valeur de 'date' est égale à 'date_end' alors l'expression 'BETWEEN date_start AND date_end' est toujours vraie.

Est-ce bien cela?
c'est exactement ça !
Citation:
Envoyé par gb-ch
Autre question: si un champs date contient la valeur '0000-00-00' est-ce la même chose que la valeur NULL (et donc COALESCE reste utile dans ce cas)?
non, 0 (ou en date, '0000-00-00') et NULL n'ont rien à voir et ne répondent pas aux mêmes règles de calcul.

la solution peut être de remplacer tes 0 par des NULL dans la base, ou de faire la même chose dynamiquement dans la requête avec NULLIF, ou encore de faire une condition complexe avec CASE WHEN.
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun 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 07h30.


 
 
 
 
Partenaires

Hébergement Web