日期:2014-05-17  浏览次数:20690 次

求一条SQL,谢谢
表结构如下:
   TB_City             TB_Mobile
CityID CityName   MobileID  MobileName
  1      北京        1         Iphone
  2      上海        2         Android
  3      武汉

     TB_Main
ID CityID MobileID
1   北京   Iphone
2   北京   Android
3   上海   Iphone
4   上海   Iphone

结果如下:
CityID  MobileID  Count
北京   Iphone        1
北京   Android       1
上海   Iphone        2
上海   Android       0
武汉   Iphone        0
武汉   Android       0
sql

------解决方案--------------------

with TB_City(CityID, CityName)as(   
select   1,      '北京' union all       
select   2,      '上海' union all       
select   3,      '武汉' )
,TB_Mobile(MobileID,  MobileName)as(
select 1,         'Iphone' union all
select 2,         'Android')
,TB_Main(ID, CityID, MobileID)as(
select 1,   '北京',   'Iphone' union all
select 2,   '北京',   'Android' union all
select 3,   '上海',   'Iphone' union all
select 4,   '上海',   'Iphone')
select CityName,MobileName,COUNT(id) from TB_City join TB_Mobile 
on 1=1 left join TB_Main on TB_Main.CityID=TB_City.cityname and TB_Mobile.MobileName=TB_Main.MobileID
group by CityName,MobileName order by 1,2 desc

------解决方案--------------------
select c.CityName as CityID
,m.MobileName as MobileID
,count(ma.ID) as Count
from TB_City c cross join TB_Mobile m
left join TB_Main ma
on ma.CityID=c.CityName and ma.MobileID=m.MobileName
group by c.CityName
,m.MobileName

------解决方案--------------------
USE test
GO


-->生成表TB_City

if object_id('TB_City') is not null 
drop table TB_City
Go
Create table TB_City([CityID] smallint,[CityName] nvarchar(2))
Insert into TB_City
Select 1,N'北京'
Union all Select 2,N'上海'
Union all Select 3,N'武汉'