2011-12-20 14 views
29
(SELECT COUNT(motorbike.`owner_id`) as count,owner.`name`,transport.`type` FROM transport,owner,motorbike WHERE transport.type='motobike' 
AND owner.`owner_id`=motorbike.`owner_id` 
AND transport.`type_id`=motorbike.`motorbike_id` GROUP BY motorbike.owner_id) 
UNION ALL 
(SELECT COUNT(car.`owner_id`) as count,owner.`name`,transport.`type` FROM transport,owner,car WHERE transport.type='car' 
AND owner.`owner_id`=car.`owner_id` 
AND transport.`type_id`=car.`car_id` GROUP BY car.`owner_id`) 

क्वेरी के ऊपर इस नीचे की तरह एक परिणाम देता है के साथ द्वारा,समूह संघ mysql का चयन क्वेरी

count   name 
1    Linda 
2    Mary 
1    Steve 
1    Linda 

इस क्वेरी कि कितने परिवहन एक मालिक के स्वामित्व में गिनती करने के लिए है। लिंडा एक कार और एक मोटरसाइकिल है, तो परिणाम चाहिए:

count   name 
2    Linda 
2    Mary 
1    Steve 

मैं इस क्वेरी की कोशिश की है, लेकिन वापसी त्रुटि:

(SELECT COUNT(motorbike.`owner_id`),owner.`name`,transport.`type` FROM transport,owner,motorbike WHERE transport.type='motobike' 
AND owner.`owner_id`=motorbike.`owner_id` 
AND transport.`type_id`=motorbike.`motorbike_id`) 
UNION ALL 
(SELECT COUNT(car.`owner_id`),owner.`name`,transport.`type` FROM transport,owner,car WHERE transport.type='car' 
AND owner.`owner_id`=car.`owner_id` 
AND transport.`type_id`=car.`car_id`) GROUP BY motorbike.owner_id 

किसी को भी मेरी मदद कर सकते हैं?

उत्तर

85
select sum(qty), name 
from (
    select count(m.owner_id) as qty, o.name 
    from transport t,owner o,motorbike m 
    where t.type='motobike' and o.owner_id=m.owner_id 
     and t.type_id=m.motorbike_id 
    group by m.owner_id 

    union all 

    select count(c.owner_id) as qty, o.name, 
    from transport t,owner o,car c 
    where t.type='car' and o.owner_id=c.owner_id and t.type_id=c.car_id 
    group by c.owner_id 
) t 
group by name 
+0

इसका काम .. बहुत धन्यवाद;) – user1103332

+0

ऐसा करने का एक आसान तरीका है, फिर भी मैंने कभी इसके बारे में सोचा नहीं होगा। बहुत बढ़िया! – alanaktion

+0

आप ऑर्डर और सीमा कैसे जोड़ते हैं? –

1

संपादित का प्रयास करें:

(SELECT COUNT(motorbike.owner_id),owner.name,transport.type FROM transport,owner,motorbike WHERE transport.type='motobike' AND owner.owner_id=motorbike.owner_id AND transport.type_id=motorbike.motorbike_id GROUP BY motorbike.owner_id) 

UNION ALL 

(SELECT COUNT(car.owner_id),owner.name,transport.type FROM transport,owner,car WHERE transport.type='car' AND owner.owner_id=car.owner_id AND transport.type_id=car.car_id GROUP BY car.owner_id) 
+0

मैं समूह की कोशिश की है car.owner_id करके, लेकिन अभी भी वापसी त्रुटि – user1103332

+0

त्रुटि है क्या कि तुमको मिल रहा है? अगर मेरे पास त्रुटि पाठ है, तो मैं –

+0

समस्या को बेहतर तरीके से डीबग कर सकता हूं त्रुटि कोड: 1064 यह त्रुटि मुझे मिलती है। आपके SQL वाक्यविन्यास में आपको एक त्रुटि है; 'GROUP BY car.owner_id – user1103332

3

यह हो सकता है कि आपके बाद:

SELECT Count(Owner_ID), Name 
FROM (
    SELECT M.Owner_ID, O.Name, T.Type 
    FROM Transport As T, Owner As O, Motorbike As M 
    WHERE T.Type = 'Motorbike' 
    AND O.Owner_ID = M.Owner_ID 
    AND T.Type_ID = M.Motorbike_ID 

    UNION ALL 

    SELECT C.Owner_ID, O.Name, T.Type 
    FROM Transport As T, Owner As O, Car As C 
    WHERE T.Type = 'Car' 
    AND O.Owner_ID = C.Owner_ID 
    AND T.Type_ID = C.Car_ID 
) 
GROUP BY Owner_ID 
संबंधित मुद्दे