Ce problème peut sembler être du travail scolaire, mais ce n'est pas le cas. Au mieux, c'est un travail scolaire auto-imposé. J'encourage tous les enseignants à prendre comme exemple s'ils le souhaitent.Le problème de requête «premier après l'élection»
Les élections "au premier tour du scrutin" sont à un tour, ce qui signifie que ceux qui obtiennent le plus de voix gagnent, pas de deuxième tour. Supposons une table pour un choix.
CREATE TABLE ElectionResults (
DistrictHnd INTEGER NOT NULL,
PartyHnd INTEGER NOT NULL,
CandidateName VARCHAR2(100) NOT NULL,
TotalVotes INTEGER NOT NULL,
PRIMARY KEY DistrictHnd, PartyHnd);
Le tableau a deux clés étrangères: points de DistrictHnd à une table de district (répertorie toutes les différentes Circonscriptions électorales) et des points de PartyHnd à une table Party (répertorie tous les différents partis politiques). Je ne vais pas déranger avec d'autres tables ici, les rejoindre est trivial. C'est juste un petit peu de contexte.
La question: Quelle requête SQL retournera un tableau listant les DistrictHnd, PartyHnd, CandidateName et TotalVotes des gagnants (votes maximum) dans chaque District?
Cela ne suppose aucun système de base de données particulier. Si vous souhaitez vous en tenir à une implémentation particulière de SQL, allez dans SQLite et MySQL. Si vous pouvez concevoir un meilleur schéma (ou un schéma plus simple), cela est également acceptable. Critères: simplicité, portabilité vers d'autres bases de données.
Hnd? Quel est le problème avec ID? –
Force d'habitude. En règle générale, j'utilise ID pour toute forme d'entier reconnaissable, et Hnd pour tout autre élément interne susceptible d'être auto-incrémenté. – MPelletier