Requête sur MySQL

hakim_fth Messages postés 138 Date d'inscription   Statut Membre Dernière intervention   -  
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   -
Bonjour,

Comment SVP je peux obtenir le résultat ci-dessous à partir de cette table


j'ai essayé le code:
SELECT matricule, date, a.statut, b.statut, c.statut, d.statut FROM pointage, a.pointage, b.pointage, c.pointage, d.pointage GROUP BY date

7 réponses

yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   Ambassadeur 1 584
 
bonjour,
peux-tu donner un exemple plus complexe?
0
hakim_fth Messages postés 138 Date d'inscription   Statut Membre Dernière intervention  
 
Bonjour,

Je ne trouve pas plus complexe que ça pour le moment, j'ai beaucoup essayer de trouver la requête mais envain
0
yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   1 584
 
l'exemple est trop court, il ne permet pas de comprendre ce que tu veux faire.
ajoute des éléments.
0
hakim_fth Messages postés 138 Date d'inscription   Statut Membre Dernière intervention  
 
Bonsoir yg_be,

J'ai une table nommée "pointage" sur MySQL comme le montre l'image ci-dessous


Je souhaite afficher le résultat ci-dessous depuis la table pointage (J'utilise PHP)
0
yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   1 584
 
Si tu utilises PHP, tu peux facilement réaliser cela avec un peu de SQL et un peu de PHP.
A condition d'apprendre l'un et l'autre.
0
hakim_fth Messages postés 138 Date d'inscription   Statut Membre Dernière intervention  
 
Je n'ai pas de problème par rapport à PHP, mais le problème que j'ai c'est que je ne trouve toujours pas la requête convenable pour le faire. Si tu peux m'aider :)
0
yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   1 584
 
La requête suivante te fournira toutes les données, tu n'auras pas de problème à programmer en PHP pour les présenter comme tu le souhaites.
SELECT matricule, date, statut FROM pointage
ORDER BY matricule, date, statut
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
Rototo
 
Salut,
vu que les champs Entree, Pause Sortie, Pause Entree n'existent pas dans la table comment comptez vous les obtenir(d'où viennent ces données)?
Si c'est une valeur calculée il faut inclure le calcul, si c'est une valeur d'une autre table il faut que celle ci soit liées(voir les jointures de table en SQL).
Sinon dans votre requête(dans le 1er message) si vous voulez uniquement une ligne (ou 2) il faut utiliser la clause WHERE pour ne pas obtenir toutes les données de la table.
Je ne comprends pas non plus le group by (vu que vous désirez une ligne de données ce n'est forcément pas un groupe) et encore moins votre utilisation de plusieurs alias...

En général une table seule ce n'est pas suffisant(ou très mal organisé). Pensez avant tout à organiser vos entités de données(qui donneront les tables) de façon à ce que le programme puisse être efficient:
moins de développement, fonctionnement clair et efficace qui empêche toute erreur dans la table et surtout correspond aux nécessités de votre système d'information.

Bref penser l'organisation des données avant de faire les tables qui doivent être le résultat de ce que vous désirez obtenir.
0
hakim_fth Messages postés 138 Date d'inscription   Statut Membre Dernière intervention  
 
Salut,

Merci Rototo pour ton retour,
Pour Entree, Sortee, ... ce sont les codes du statut
1 = Entree
2 = Pause Sortie
3 = Pause Entree
4 = Sortie

J'espère que c'est claire maintenant. C'est une seule table c'est juste le libellé statut qui change
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Bonjour,

SELECT T.matricule
  , T.date
  , MAX(T.ENTREE) AS E
  , MAX(T.PAUSE_SORTIE) AS PS
  , MAX(T.PAUSE_ENTREE) AS PE
  , MAX(T.SORTIE) AS S
FROM (
 SELECT matricule
  ,date 
  ,IF(statut=1 , 1 , "*") AS ENTREE
  ,IF(statut=2 ,2,"*") AS PAUSE_SORTIE
  ,IF(statut=3,3,"*") AS PAUSE_ENTREE
  ,IF(statut=4,4,"*") AS SORTIE    
 FROM pointage
) T
GROUP BY T.matricule, T.date


NB: Faudra désactiver le ONLY_FULL_GROUP_BY pour que ça fonctionne
https://stackoverflow.com/questions/23921117/disable-only-full-group-by



0