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 -
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:
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
A voir également:
- Requête sur MySQL
- Mysql community server - Télécharger - Bases de données
- Mysql error 2002 ✓ - Forum Linux / Unix
- Erreur lors de l'envoi de la requête facebook - Forum Facebook
- Erreur de requete facebook - Forum Facebook
- Mysql a répondu : documentation connexion impossible : paramètres incorrects. - Forum Bases de données
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?
peux-tu donner un exemple plus complexe?
Bonjour,
Je ne trouve pas plus complexe que ça pour le moment, j'ai beaucoup essayer de trouver la requête mais envain
Je ne trouve pas plus complexe que ça pour le moment, j'ai beaucoup essayer de trouver la requête mais envain
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)

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)
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 :)
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
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.
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.
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
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
Bonjour,
NB: Faudra désactiver le ONLY_FULL_GROUP_BY pour que ça fonctionne
https://stackoverflow.com/questions/23921117/disable-only-full-group-by

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
