Requete mysql minimum

Fermé
Ptesoleil Messages postés 27 Date d'inscription jeudi 17 avril 2008 Statut Membre Dernière intervention 27 août 2008 - 26 août 2008 à 23:48
Christounet Messages postés 1264 Date d'inscription mercredi 26 septembre 2007 Statut Membre Dernière intervention 29 juillet 2010 - 28 août 2008 à 11:19
Bonjour,
j'ai une requete à faire en mysql mais je ne sais pas comment m'y prendre.
Je dois trouver le minimum et le maximum d'un champ KMValue: jusque là pas de probleme. Cependant j'ai deux tables KM : c'est à dire KMP et KMS donc avec chacun un champ KMPValue et KMSValue. Comment je peux trouver le minimum sur ces deux champs (aucune jointure directe n'est possible) ?
Et ensuite, il faut que je trouve le second miminum?
Merci de votre aide.

7 réponses

Christounet Messages postés 1264 Date d'inscription mercredi 26 septembre 2007 Statut Membre Dernière intervention 29 juillet 2010 1 385
27 août 2008 à 12:30
Bonjour Ptesoleil,
Le code suivant devrait faire ce que tu veux
SELECT LeMin
FROM
(SELECT Min(KMPValue) AS LeMin
FROM KMP
UNION
SELECT Min(KMSValue) AS LeMin
FROM KMS)
ORDER BY LeMin ASC;

Tu devrais avoir comme résultat deux nombres triés par ordre ascendant.
Pour le maximum, le code devrait être le suivant
SELECT LeMax
FROM
(SELECT Max(KMPValue) AS LeMax
FROM KMP
UNION
SELECT Max(KMSValue) AS LeMax
FROM KMS)
ORDER BY LeMax DESC;

Dans ce cas ci tu auras deux nombres triés par ordre descendant.
A plus
0
Rctll Messages postés 499 Date d'inscription dimanche 11 mai 2008 Statut Membre Dernière intervention 30 juin 2010 1 426
27 août 2008 à 00:23
Bonjour,
Un fonction de ce style correspond-t-elle a ce que tu cherche ?
Select if(min(p.kmpValue)<min(s.kmsValue),min(p.kmpValue),min(s.kmsValue)) as minimum from KMP as p, KMS as s;
-1
Ptesoleil Messages postés 27 Date d'inscription jeudi 17 avril 2008 Statut Membre Dernière intervention 27 août 2008
27 août 2008 à 00:52
Cette requete permet d'afficher le deuxieme minimum c'est ce que je voulais mais peux tu m'expliquer comment elle fonctionne? et comment dans cette meme requete puis-je afficher aussi le premier minimum?
-1
Rctll Messages postés 499 Date d'inscription dimanche 11 mai 2008 Statut Membre Dernière intervention 30 juin 2010 1 426
27 août 2008 à 00:57
Elle Affiche le Deuxieme minimum? j'ai du faire une erreur alors :s , elle devrait afficher la plus petite valeur existante ...
es ce que tu peux decrire totalement tes 2 tables? j'ai du mal comprendre
( j'ai interprété comme çà :
Table KMP: plein de champs dont kmpValue
table KMS : plein de champs dont KMSValue, et je croyait que ton but était d'obtenir la plus petite valeur d'entre ces 2 champs .. c'est pas çà ? )
-1

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

Posez votre question
Ptesoleil Messages postés 27 Date d'inscription jeudi 17 avril 2008 Statut Membre Dernière intervention 27 août 2008
27 août 2008 à 09:11
Si c'est bien ca, tu as bien compris. 2 tables : KMP et KMS avec chacune plusieurs champs dont dans la première KMPValue et dans la deuxième KMSValue. Mais cela n'affiche pas la plus petite valeur. Dans mes tables j'ai vérifié et la plus petite valeur est dans KMP et cela m'affiche celle de KMS qui correspond aux dieuxieme minimum).
-1
Ptesoleil Messages postés 27 Date d'inscription jeudi 17 avril 2008 Statut Membre Dernière intervention 27 août 2008
27 août 2008 à 14:41
Ok merci beaucoup
Mais j'ai une autre question :

KMPValue et KMSValue sont des varchars ; seulement pour faire des opérations je dois les passer en float.
J'ai fait ceci :

(SELECT KMPValue AS Value
FROM KMP
UNION
SELECT KMSValue AS Value
FROM KMS
ORDER BY 0+Value DESC
LIMIT 1);

Dans les deux tables la plus grande valeur est : 898 et ensuite 9.9 . Avec cette requete, j'obtiens 1000! Si je ne mets pas 0+Value, j'obtiens 9.9. Pourquoi cette arrondi à 1000 et comment dois je resoudre le probleme?
-1
Christounet Messages postés 1264 Date d'inscription mercredi 26 septembre 2007 Statut Membre Dernière intervention 29 juillet 2010 1 385
28 août 2008 à 11:19
Bonjour,

Tu peux utiliser l'instruction CAST, le code ci-dessous devrait t'aider
(SELECT CAST(KMPValue as DECIMAL(5,2)) AS Value
FROM KMP
UNION
SELECT CAST(KMSValue as DECIMAL(5,2)) AS Value
FROM KMS
ORDER BY Value DESC
LIMIT 1);

L'instruction CAST va convertir ta variable en un nombre décimal de 5 chiffres et 2 chiffres après la virgule.

A plus
-1