求SQL语句,在线等(行转列问题)
现在有2张表:dbo.ChargeOriginByDeviceCode和dbo.Origin
第一张表的数据有:
date originid devicecode price usercount
2012-02-14 787 gbox 200 12
2012-02-14 788 xggbox 400 20
2012-02-14 789 gbox 300 300
2012-02-14 790 gboxmtk 500 250
另一张表:
originid originname
787 艾丽卡
788 艾丽卡
789 艾丽卡
790 艾丽卡
我现在想要的结果:根据originname为艾丽卡的originid的钱数
date 787gbox 788xggbox 789gbox 790gboxmtk
2012-02-14 200 400 300 500
表头是第一张表中的originid+devicecode组成的
请问各位,这个要怎么办呢?
[解决办法]
动态的执行方法:
declare @sql varchar(8000)select @sql = isnull(@sql + '],[' , '') + exp1 from ( select c.originid + devicecode as exp1 from ChargeOriginByDeviceCode c,Origin o where c.originid = o.originid and o.originname = '艾丽卡' ) aset @sql = '[' + @sql + ']'set @sql = ' select * from ( select date, c.originid + devicecode as exp1, c.price from ChargeOriginByDeviceCode c,Origin o where c.originid = o.originid and o.originname = ''艾丽卡'' ) a pivot ( sum(price) for exp1 in (' + @sql + ')) as t'exec (@sql)