J'apprends manuel mysql: http://dev.mysql.com/doc/refman/5.6/en/example-maximum-column-group-row.html et je suis confondu avec le « where.s1.article = s2.article » une partie, ce qui est ce que cela signifiesous-requête mysql où et par groupe
Task: For each article, find the dealer or dealers with the most expensive price.
+---------+--------+-------+
| article | dealer | price |
+---------+--------+-------+
| 0001 | A | 3.45 |
| 0001 | B | 3.99 |
| 0002 | A | 10.99 |
| 0003 | B | 1.45 |
| 0003 | C | 1.69 |
| 0003 | D | 1.25 |
| 0004 | D | 19.95 |
+---------+--------+-------+
SELECT article, dealer, price
FROM shop s1
WHERE price=(SELECT MAX(s2.price)
FROM shop s2
WHERE s1.article = s2.article);
+---------+--------+-------+
| article | dealer | price |
+---------+--------+-------+
| 0001 | B | 3.99 |
| 0002 | A | 10.99 |
| 0003 | C | 1.69 |
| 0004 | D | 19.95 |
+---------+--------+-------+
?
Je suis en train d'écrire le code similaire:
SELECT sex, name, birthday
From user
Where birthday=(SELECT MAX(birthday)
FROM user
group by sex);
Mais mes sorties l'erreur: retour de sous-requête plus de 1 ligne, pourquoi
Je ne suis pas sûr, je peux me tromper, mais je pense que c'est parce que 'la sous-requête renvoie plus de 1 rangée'. – Sebas