A表中有4个字段,出生省份ID,出生城市ID,居住省分ID,居住城市ID
B有省分ID,省分名称
C表有城市ID,省分名称
现在要查出A表中的所有数据,并将各ID换成具体的省,市名称。
create table a(birthProvinceID int,brithCityID int ,liveProvinceID int,liveCityID int)create table b(provinceID int ,provinceName nvarchar(10))create table c(cityID int,cityName nvarchar(10))insert a values(1,1,2,2)insert b values(1,N'云南')insert b values(2,N'北京')insert c values(1,N'昆明')insert c values(2,N'东城区')
上边是测试数据,请问怎么写效率最高?谢谢!
6 回答
PIPIONE
TA贡献1829条经验 获得超9个赞
--这样应该是效率最高的了 只有left join 没有子查询 select a.*, b1.provinceName as birthProvince, c1.cityName as birthCity, b2.provinceName as liveProvince, c2.cityName as liveCity from a left join b b1 on a.birthProvinceID = b1.provinceID left join c c1 on a.birthCityID = c1.cityID left join b b2 on a.liveProvinceID = b2.provinceID left join c c2 on a.liveCityID = c2.cityID
Helenr
TA贡献1780条经验 获得超4个赞
SET STATISTICS IO ON ;
WITH tab1
AS ( SELECT a.* ,
b.provinceName AS BirthProvinceName
FROM dbo.a WITH(NOLOCK)
INNER JOIN dbo.b WITH(NOLOCK) ON a.birthProvinceID = b.provinceID
),
tab2
AS ( SELECT BirthProvinceName ,
liveCityID ,
tab1.brithCityID ,
B.provinceName ,
b.provinceName AS LiveProvinceName
FROM tab1 WITH(NOLOCK)
INNER JOIN dbo.b WITH(NOLOCK) ON tab1.liveProvinceID = b.provinceID
),
tab3
AS ( SELECT tab2.* ,
c.cityName AS BirthCityName
FROM tab2 WITH(NOLOCK)
INNER JOIN dbo.c WITH(NOLOCK) ON tab2.brithCityID = c.cityID
)
SELECT BirthProvinceName ,
BirthCityName ,
LiveProvinceName ,
c.cityName AS LiveCityName
FROM TAB3 WITH(NOLOCK)
INNER JOIN c WITH(NOLOCK) ON tab3.liveCityID = c.cityID
SET STATISTICS IO OFF
慕虎7371278
TA贡献1802条经验 获得超4个赞
select B.provinceName as BirthProvince , C.cityName as BirthCity ,LiveProvince, LiveCity
from B, C, select birthProvinceID ,brithCityID, provinceName as LiveProvince , cityName as LiveCity
from A, B, C
where A.liveProvinceID=B. provinceName and A.liveCityID=C.cityName
M
where M.birthProvinceID=B. provinceName and M.birthCityID=C.cityName
- 6 回答
- 0 关注
- 681 浏览
添加回答
举报
0/150
提交
取消