sql >> Database >  >> RDS >> Mysql

SUM() gebaseerd op een andere voorwaarde dan de SELECT

U kunt de som ook in een case-statement plaatsen, waar de case de andere voorwaarde evalueert, en dan alleen die records optellen waar de voorwaarde waar is...

  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. MySQL-volgorde op tekenreeks met cijfers

  2. Speel 2.4 - Slick 3.0.0 - VERWIJDEREN werkt niet

  3. PowerManager.PARTIAL_WAKE_LOCK Android

  4. Postgresql - Kolommen hernummeren