数据透视表是分析数据的一种方法在Excel中就包含了强大的数据透视功能数据透视是什么样的呢?给个例子可能更容易理解假设有一张数据表
销售人员 书籍 销量
小王 Excel教材
小李 Excel教材
小王Word教材
小李 Excel教材
小王 Excel教材
小李 Excel教材
小王 Word教材
小李 Excel教材
一种数据透视的方法是统计每个销售人员对每种书籍的销量 结果如下
Excel教材 Word教材 总计
小王
小李
各位看明白了吗?这是最简单的一种数据透视了如果有必要也可以有多级分组
好了那在Sql Server中如何视现数据透视的功能呢?我是Sql Server的初学者看了网上的一些例子结合自己的理解写了下面这些Sql语句
生成基础数据的代码
Create table s(
[name] nvarchar()
book nvarchar()
saledNumber int
)
insert into s ([name]booksaledNumber) values(小王Excel教材);
insert into s ([name]booksaledNumber)values(小李Excel教材);
insert into s ([name]booksaledNumber)values(小王Word教材);
insert into s ([name]booksaledNumber)values(小李Excel教材);
insert into s ([name]booksaledNumber)values(小王Excel教材);
insert into s ([name]booksaledNumber)values(小李Excel教材);
insert into s ([name]booksaledNumber)values(小王Word教材);
insert into s ([name]booksaledNumber)values(小李Excel教材);
生成数据透视表
set @sql = SELECT [name]
select @sql = @sql + sum(case book when +quotename(book)+ then saledNumber else end) as + quotename(book)+ from s group by book
select @sql = left(@sqllen(@sql))
select @sql = @sql + sum(saledNumber) as [sum] from s group by [name]
select @sql
exec(@sql)
上面的查询语句首先是拼接了一条"Sql语句"它的最终结果为:
SELECT [name] sum(case book when Excel教材 then saledNumber else end) as [Excel教材]sum(case book when Word教材 then saledNumber else end) as [Word教材] sum(saledNumber) as [sum] from s group by [name]
当然如果表中的数据不同那么这生成的Sql语句也是不同的最后它调用了Sql Server的系统存储过程Exec来执行这条语句截个图吧
这就是在Sql Server中生成数据透视表的实现其实它的核心也就是上面拼接成的那条Sql语句更复杂的透视方式比如多级透视也是在这个基础上的实现的