40

Crosstab queries using PIVOT in SQL Server

 5 years ago
source link: https://www.tuicool.com/articles/hit/zMjMr2r
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

Problem

In SQL Server 2000 there was not a simple way to create cross-tab queries, but a new option first introduced in SQL Server 2005 has made this a bit easier. We took a look at how to create cross-tab queries in SQL Server 2000 in thisprevious tip and in this tip we will look at the SQL Server PIVOT feature to allow you produce cross-tab results.

Solution

We will use the SQL Server PIVOT to create cross-tab results and show an example.

Let's say we have data in a table that looks like this:

SalesPerson Product SalesAmount Bob Pickles $100.00 Sue Oranges $50.00 Bob Pickles $25.00 Bob Oranges $300.00 Sue Oranges $500.00

And what we want to do is to rearrange the output to look like below. First you have the data rows such as SalesPerson, and then columns for each Product with the summarized SalesAmount value for each cross section.

SalesPerson Oranges Pickles Bob $300.00 $125.00 Sue $550.00

Let's create a sample table and insert some data that we can use with a PIVOT query.

CREATE TABLE ProductSales
( SalesPerson varchar(20),
  Product varchar(20),
  SalesAmount money )
GO

INSERT INTO ProductSales
SELECT 'Bob','Pickles',100.00
UNION
SELECT 'Sue','Oranges',50.00
UNION
SELECT 'Bob','Pickles',25.00
UNION
SELECT 'Bob','Oranges',300.00
UNION
SELECT 'Sue','Oranges',500.00  
GO

Here is a simple PIVOT query that allows us to pull the cross-tab results as shown above.

SELECT SalesPerson, [Oranges] AS Oranges, [Pickles] AS Pickles
FROM 
   ( SELECT SalesPerson, Product, SalesAmount
     FROM ProductSales 
   ) ps
PIVOT
   ( SUM (SalesAmount)
     FOR Product IN ( [Oranges], [Pickles])
   ) AS pvt

So how does this work?

There are three pieces that need to be understood in order to construct the query.

  • (1) The SELECT statement
    • SELECT SalesPerson, [Oranges] AS Oranges, [Pickles] AS Pickles
    • This portion of the query selects the three columns for the final result set (SalesPerson, Oranges, Pickles)
  • (2) The query that pulls the raw data to be prepared
    • ( SELECT SalesPerson, Product, SalesAmount FROM ProductSales) ps
    • This query pulls all the rows of data that we need to create the cross-tab results.  The (ps) after the query is creating a temporary table of the results that can then be used to satisfy the query for step 1.
  • (3) The PIVOT expression
    • PIVOT (SUM (SalesAmount) FOR Product IN ( [Oranges], [Pickles]) ) AS pvt
    • This query does the actual summarization and puts the results into a temporary table called pvt

Another key thing to notice in here is the use of the square brackets [ ] around the column names in both the SELECT in part (1) and the IN in part (3).  These are key, because the pivot operation is treating the values in these columns as column names and this is how the breaking and grouping is done to display the data.

Next Steps

  • Take a look at the new PIVOT option that SQL Server offers to see how you can use this
  • Review the older methods that were discussed in thisprior tip.  These options will still work in all versions of SQL Server and may provide a better solution.
  • Try to write some more complex queries to take advantage of this new option.
  • Also take a look at this tip that dynamically creates the PIVOT query instead of having to hard code the query.

Last Updated: 2019-03-22


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK