أريد العثور على مجموع أعداد الجداول في SQL

0

تجدون أدناه الاستعلام الذي أستخدمه

select cm.city_name,

count(case when k.listing_status_uid=1 then 1 end ) as 'Active',   
count(case when k.listing_status_uid=3 then 1 end ) as 'Bad_listing',  
count(case when k.listing_status_uid=4 then 1 end ) as 'proj_scrapped',  
count(case when k.listing_status_uid=5 then 1 end ) as 'proj_on_hold',  
count(case when k.listing_status_uid=6 then 1 end ) as 'sold_out',  
count(case when k.listing_status_uid=7 then 1 end ) as 'others'

from ksl_listing_master k  
join ksl_locality_master lm on lm.locality_uid=k.listing_locality  
join ksl_city_master cm on cm.city_uid=lm.city_uid  
join ksl_listing_status ls on ls.listing_status_uid=k.listing_status_uid  

group by cm.city_name

يعطي هذا ناتجًا مثل الناتج أدناه

Imagen 104

الآن أريد مجموع كل عمود على حدة. يجب أن يكون المبلغ الموجود أسفل أسماء المدن مجموعًا فرديًا Active ، Bad_listing ، proj_scrapped ، proj_on_hold ، sold_out و others في نفس الاستعلام.

2 الاجابة

2
افضل جواب

إذا فهمت بشكل صحيح ، فأنت تريد فقط صف ملخص. يمكنك القيام بذلك باستخدام with rollup :

select . . .
group by cm.city_name with rollup;
:مؤلف
0

يبدو أنك تريد:

select cm.city_name,
       sum(k.listing_status_uid = 1) as 'Active',   
       sum(k.listing_status_uid = 3) as 'Bad_listing',  
       sum(k.listing_status_uid = 4) as 'proj_scrapped',  
       . . .
       sum(k.listing_status_uid in (1,3,4)) as 'total'
from ksl_listing_master k join 
     ksl_locality_master lm 
     on lm.locality_uid = k.listing_locality join 
     ksl_city_master cm 
     on cm.city_uid=lm.city_uid join 
     ksl_listing_status ls 
     on ls.listing_status_uid = k.listing_status_uid  
group by cm.city_name;
:مؤلف
فوق
قائمة طعام