I’m having a problem in where i want to count how many medals in total a country has won from both the individual and team competitions does not give me the disered outcome. i have managed so far tocome up with this.
select distinct C.Cname as Country, count(i.medal) as Medals_Won
from individual_results as i, Country as C, participant as p
where (i.Olympian = p.OlympicID and C.Cname = p.country)
union
select distinct C.Cname, count(r.medal) as medals_Won
from team_results as r, Country as C, participant as p, team as t
where (r.team = t.TeamID and t.Member1 = p.OlympicID and C.Cname = p.Country)
group by C.Cname
order by medals_won desc
but i get this result.
even tho if i run the two separate pieces of code i ge the wanted restuls that is enter image description here
2
Answers
You should sum the union result for each of the subquery grouped by cname
You say you can run your query and it gives you a result. This is bad. It indicates that you are MySQL’s notorious cheat mode that lets you run invalid queries.
You have something like this:
There are two queries the results of which you glue together, namely
and
So, your first query becomes:
You
COUNT
medals, i.e. you aggregate your data. And there is noGROUP BY
clause. So you get one result row from all your data. You say you want to count all rows for which i.medal is not null. But you also want to select the country. The country? Which??? Is there just one country in the tables? And even then your query would be invalid, because still you’d have to tell the DBMS from which row to pick the country. You can pick the maximum country (MAX(C.Cname)
) for instance or the minimum country (MIN(C.Cname)
), but not the country.The DBMS should raise an error on this invalid query, but you switched that off.
Make sure in MySQL to always
It is the default in more recent versions, so either you are working with old software or you switched from good mode to bad mode voluntarily.
And talking of old software: Even at the first moment MySQL was published, comma joins had long been deprecated. They were made redudant in 1992. Please don’t ever use commas in your
FROM
clause. Use explicit joins ([INNER] JOIN
,LEFT [OUTER] JOIN
, etc.) instead.As to the task, here is a straight-forward solution with joins: