sql >> Database teknologi >  >> RDS >> PostgreSQL

Postgresql Flere tæller for en tabel

du kan bruge case i dette tilfælde -

SELECT type, 
       sum(case when place  = 'home' then 1 else 0 end) as Home,
       sum(case when  place  = 'school' then 1 else 0 end) as school,
       sum(case when  place  = 'work' then 1 else 0 end) as work,
       sum(case when  place  = 'cafe' then 1 else 0 end) as cafe,
       sum(case when  place  = 'friends' then 1 else 0 end) as friends,
       sum(case when  place  = 'mall' then 1 else 0 end) as mall
  from reports
 group by type

Det burde løse dit problem

@S T Mohammed,For at få en sådan type kan vi simpelthen bruge using efter group eller where betingelse i ydre forespørgsel, som nedenfor -

select type, Home, school, work, cafe, friends, mall from (
SELECT type, 
       sum(case when place  = 'home' then 1 else 0 end) as Home,
       sum(case when  place  = 'school' then 1 else 0 end) as school,
       sum(case when  place  = 'work' then 1 else 0 end) as work,
       sum(case when  place  = 'cafe' then 1 else 0 end) as cafe,
       sum(case when  place  = 'friends' then 1 else 0 end) as friends,
       sum(case when  place  = 'mall' then 1 else 0 end) as mall
  from reports
 group by type
 )
 where home >0 and School >0 and Work >0 and cafe>0 and friends>0 and mall>0


  1. MySQL bedste måde at gemme lange strenge på

  2. SQL-fejl ved forsøg på at oprette ny trigger

  3. Ændre AUTO_INCREMENT værdi ved at vælge resultat

  4. Lås og transaktion i postgres, der skulle blokere en forespørgsel