Self-Join with missing rows on both sides

前端 未结 2 907
醉酒成梦
醉酒成梦 2021-01-28 04:22

I have a table containing people joining and leaving an organization.

Sample data: Sql Fiddle

| pId |     pName |  Unit | YearIn | Yea         


        
2条回答
  •  醉话见心
    2021-01-28 04:53

    I think you want a subquery and aggregation:

    SELECT Year, Unit, SUM(NumIn) as NumIn, SUM(NumOut) as NumOut
    FROM (SELECT YearIn AS Year, Unit, COUNT(pId) AS NumIn, NULL AS NumOut
          FROM People
          WHERE YearIn >= 2013
          GROUP BY YearIn, Unit
          UNION ALL
          SELECT YearOut AS Year, Unit, NULL AS NumIn, COUNT(pId) AS NumOut
          FROM People
          WHERE YearOut >= 2013
          GROUP BY YearOut, Unit
         ) yu
    GROUP BY Year, Unit;
    

提交回复
热议问题