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

Tæl poster fra to tabeller grupperet efter ét felt

Det lyder som om du prøver at gøre dette:

select d.RepName, count(d.RepName) DoctorReportsCount, count(h.RepName) HospitalsReportsCount, d.DateAdded from doctorreports d inner join hospitals h on d.RepName = h.RepName group by d.RepName, d.DateAdded

rediger:

select * from ( select d.RepName, count(d.RepName) DoctorReportsCount , d.dateadded from doctorreports d group by d.RepName, d.dateadded ) d left join ( select h.RepName, count(h.RepName) HospitalsReportsCount , h.dateadded hDateadded from hospitals h group by h.RepName, h.dateadded )h on d.RepName = h.RepName

se SQL Fiddle med demo

edit #2, hvis du vil returnere data for dage, der mangler, så vil jeg råde dig til at oprette en tabel, der indeholder kalenderdatoer, så kan du returnere data for dage, der mangler. Følgende skulle returnere det, du leder efter. Vær opmærksom på, jeg oprettede en kalendertabel til denne forespørgsel:

select COALESCE(d.drep, '') repname,
  COALESCE(d.DCount, 0) DoctorReportsCount,
  COALESCE(h.HCount, 0) HospitalsReportsCount,
  c.dt Dateadded
from calendar c
left join
(
  select repname drep,
    count(repname) DCount,
    dateadded ddate
  from doctorreports
  group by repname, dateadded
) d
  on c.dt = d.ddate
left join
(
  select repname hrep,
    count(repname) HCount,
    dateadded hdate
  from hospitals
  group by repname, dateadded
) h
  on c.dt = h.hdate
  and d.drep = h.hrep

se SQL Fiddle with Demo

Hvis du er ligeglad med de andre datoer, så er det sådan, du ville gøre det uden en date tabel:

select COALESCE(d.RepName, '') repname,
  COALESCE(d.DoctorReportsCount, 0) DoctorReportsCount,
  COALESCE(h.HospitalsReportsCount, 0) HospitalsReportsCount,
  COALESCE(p.PharmacyReportsCount, 0) PharmacyReportsCount,
  d.dateadded Dateadded
from
(
  select d.RepName,
      count(d.RepName) DoctorReportsCount
    , d.dateadded
  from doctorreports d
  group by d.RepName, d.dateadded
) d
left join
(
  select h.RepName,
    count(h.RepName) HospitalsReportsCount
  , h.dateadded hDateadded
  from hospitals h
  group by h.RepName, h.dateadded
)h
  on d.RepName = h.RepName
  and d.dateadded = h.hDateadded
left join
(
  select p.RepName,
    count(p.RepName) PharmacyReportsCount
  , p.dateadded hDateadded
  from PharmacyReports p
  group by p.RepName, p.dateadded
)p
  on d.RepName = p.RepName
  and d.dateadded = p.hDateadded

se SQL Fiddle with Demo



  1. Tilføjelse af data til et MySQL-databasefelt, der allerede har data i sig

  2. Hvordan ved man, at den installerede Oracle Client er 32 bit eller 64 bit?

  3. SQL til at kopiere værdier fra en tabel til en anden

  4. Forbind mySQL med Android