数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

SQL Server 生成数据透视表


发布日期:2020年12月07日
 
SQL Server 生成数据透视表

数据透视表是分析数据的一种方法在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语句更复杂的透视方式比如多级透视也是在这个基础上的实现的

               

上一篇:win7下卸载及重新安装sql server2008详细教程

下一篇:评估期已到的SQL Server 2008怎么办