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

求助。。 sql语句问题
要得到北京和北京下属的所有区县资料。。请问后面那个lever like 应该怎么写呢
T1
cityid cityname
1 北京
2 海淀
3 丰台
4       上海
5       宝山      
T2
cityid Lever
1 1
2 11
3 12

Select * from t1 left join t2 on t1.cityid = t2.cityid wheret1.cityname = ‘北京’ and t2.lever like t2.lever + ‘%’

lever位数不一定不能用left()

------解决方案--------------------
with t1(cityid,cityname)
as(
select 1,'北京' union all
select 2,'海淀' union all
select 3,'丰台' union all
select 4,'上海' union all
select 5,'宝山'
),
T2(cityid,Lever)
as(
select 1,1 union all
select 2,11 union all
select 3,12),
cte as(
select t1.cityid,t1.cityname,t2.lever from t1 join t2 on t1.cityid=t2.cityid where t1.cityname='北京' union all
select t.cityid,t.cityname,t.lever from(select t1.cityid,t1.cityname,t2.lever  from t1 join t2 on  t1.cityid=t2.cityid)t join cte c on t.cityid!=c.cityid and left(t.lever,len(rtrim(c.lever)))=rtrim(c.lever)
)select * from cte