sql >> Databasteknik >  >> RDS >> Mysql

Räkna poster från två tabeller grupperade efter ett fält

Det låter som att du försöker göra det här:

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

redigera:

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-fiol med demo

redigera #2, om du vill returnera data för dagar som saknas, så skulle jag råda dig att skapa en tabell som innehåller kalenderdatum, då kan du returnera data för dagar som saknas. Följande bör returnera det du letar efter. Observera att jag skapade en kalendertabell för denna fråga:

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-fiol med demo

Om du inte bryr dig om de andra datumen är det så här du skulle göra det utan ett date tabell:

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-fiol med demo



  1. Hur skapar och frågar jag länkade databasservrar i SQL Server?

  2. mySQL välj postnummer inom x km/mile inom räckvidd av y

  3. MYSQL till outfil-åtkomst nekad - men min användare har ALL åtkomst.. och mappen är CHMOD 777

  4. Strategi för att synkronisera databas från flera platser till en central databas och vice versa