J'ai des comparaisons de tables. Si je lanceSélection de max d'une somme de deux colonnes
SELECT comparisonID,stu1Vers,stu2Vers,stu1,stu2
from comparisons
WHERE stu1!=stu2 and assignmentid=9;
je reçois quelque chose comme:
+--------------+----------+----------+------+------+
| comparisonID | stu1Vers | stu2Vers | stu1 | stu2 |
+--------------+----------+----------+------+------+
| 287 | 12 | 2 | 1 | 6 |
| 286 | 12 | 1 | 1 | 6 |
| 276 | 11 | 2 | 1 | 6 |
| 275 | 11 | 1 | 1 | 6 |
| 266 | 10 | 2 | 1 | 6 |
| 265 | 10 | 1 | 1 | 6 |
| 257 | 9 | 2 | 1 | 6 |
| 256 | 9 | 1 | 1 | 6 |
...
| 391 | 19 | 1 | 1 | 6 |
| 392 | 19 | 2 | 1 | 6 |
+--------------+----------+----------+------+------+
Je voudrais sélectionner toute la ligne où stu1Vers + stu2Vers est le maximum. Je continue à essayer quelque chose le long des lignes de
select c.comparisonid,c.stu1vers,c.stu2vers,max(totvers)
from comparisons as c join
(select comparisonid, stu1vers+stu2vers as totvers
from comparisons where stu1!=stu2 group by comparisonid) as cm
on c.comparisonid = cm.comparisonid and c.stu1vers+c.stu2vers = cm.totvers;
mais qui retourne un assortiment assez aléatoire des choses:
+--------------+----------+----------+--------------+
| comparisonid | stu1vers | stu2vers | max(totvers) |
+--------------+----------+----------+--------------+
| 220 | 1 | 1 | 21 |
+--------------+----------+----------+--------------+
Je suis en train de faire ramer 392 dans la première table.
Renvoyez-les tous, ou juste un? Si ce dernier, lequel? –
Il y a en fait deux autres colonnes dans la table, une pour chaque id de stu1 et stu2. Revenez donc tous, mais groupés par stu1 ou stu2). max (stu1vers + stu2vers) est garanti pour être unique pour n'importe quel étudiant pour n'importe quelle affectation. –