读书人

求SQL语句(行转列有关问题)

发布时间: 2012-03-22 17:43:57 作者: rapoo

求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组成的
请问各位,这个要怎么办呢?


[解决办法]
动态的执行方法:

SQL code
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) 

读书人网 >SQL Server

热点推荐