码迷,mamicode.com
首页 > 数据库 > 详细

sql 理解

时间:2014-12-24 11:47:27      阅读:202      评论:0      收藏:0      [点我收藏+]

标签:

select b.*, 
b.model_ent_name+cast(m.year as varchar)as modelname,
m.index_value as val

into #tb
from
(
select a.*,erm.model_ent_name
from
(select w.uuid,w.indexdef_id,
i.index_name, i.index_def,
case when w.years=2014 then w.actual_value else 0 end as k1,
case when w.years=2013 then w.actual_value else 0 end as k2,
case when w.years=2012 then w.actual_value else 0 end as k3,
case when w.years=2011 then w.actual_value else 0 end as k4,
case when w.years=2010 then w.actual_value else 0 end as k5
from bm_work w,bm_index i 
where w.indexdef_id=i.uuid 
and w.ent_id=‘2c90e4da49514c750149515eb56f0003‘ and w.summary_state=2
 and years=2014
)a left join bm_ent_rel_me erm on a.uuid=erm.bmwork_id
 
)b


left join bm_model_ent m on b.indexdef_id=m.index_def_id and b.model_ent_name=m.model_ent_name


declare @sql varchar(8000)
select @sql=isnull(@sql+‘,‘,‘‘)+modelname from #tb group by modelname
set @sql = ‘select * from #tb pivot (sum(val) for modelname in (‘+@sql+‘) )a‘
exec (@sql)


drop table #tb

技术分享


需要将上图变为下图结果。

技术分享

实现行转列,及把第一张图片中红圈的部分的内容放置到 列上,作为列的标题。。。


declare @sql varchar(8000)
select @sql=isnull(@sql+‘,‘,‘‘)+modelname from #tb group by modelname                       
set @sql = ‘select * from #tb pivot (sum(val) for modelname in (‘+@sql+‘) )a‘                      //val 为值      modelname为需要将行转列 
exec (@sql)

//写这种sql的思路就是,先自己写出类似图一 的结果,确定那一个需要行转列。。这里我们就是需要modelname 这一列的值,都放过去作为列的属性名。。。看图两个圈的描述吧。具体本人也不是很好描述。






sql 理解

标签:

原文地址:http://blog.csdn.net/baicp3/article/details/42121301

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!