sql >> Database teknologi >  >> RDS >> Mysql

SUM() baseret på en anden betingelse end SELECT

Du kan også lægge summen inde i en sagserklæring, hvor sagen evaluerer den anden betingelse, og derefter kun summere disse poster, hvor betingelsen er sand...

  SELECT m.member_id, m.teamname, 
    Sum(Case When r.track_Id = '$chosentrack' 
         Then total_points Else 0 End) TotalChosenTrackPoints,
    Sum(Case When r.track_Id < '$chosentrack' 
         Then total_points Else 0 End) TotalLessThanChosenTrackPoints, 
    total_points as last_race_points  
 FROM members m
    Join members_leagues l
       On l.member_id = m.member_id  
    Join member_results r
       On r.member_id = m.member_id
 Where l.league_id = '$chosenleague'
    And l.start_race = '$chosentrack'
 Group By m.member_id
 Order By r.total_points Desc, 
     last_race_points  Desc, m.TeamName Desc  


  1. PK krænket i oracle sql

  2. Hvordan kontrollerer man rollen for den nuværende PostgreSQL-bruger fra Qt-applikationen?

  3. Opdater flere rækker i en tabel fra en anden tabel, når betingelsen eksisterer

  4. beskytter browsere brugernes IP-adresse?