SQL交叉表的实现

时间:2021-10-10 04:49:56
  
        问题的提出:       
SQL交叉表的实现如何把以下形式
SQL交叉表的实现FItemID     FName         FStockID    FDeptID        FAuxQty                                               
SQL交叉表的实现----------- --------
SQL交叉表的实现337         生产部       598         327         1000.0
SQL交叉表的实现337         包装车间     624         605         1000.0
SQL交叉表的实现339         包装车间     598         605         200.0
SQL交叉表的实现.              .          
SQL交叉表的实现.              .  
SQL交叉表的实现.              .
SQL交叉表的实现转为这个形式
SQL交叉表的实现FItemID    生产部      包装车间 SQL交叉表的实现 FStockID
SQL交叉表的实现----------- --------
SQL交叉表的实现337        1000                  .      598
SQL交叉表的实现337        0           1000      .      624
SQL交叉表的实现339        0           200       .      598 
SQL交叉表的实现

        从上面我们可以看出,得到的结果就是要实现一个交叉表,要解决以上问题,最简单的方法就是用CASE函数。让我们先来看看CASE函数的释义:
SQL交叉表的实现CASE 函数是特殊的 Transact-SQL 表达式,它允许按列值显式可选值。数据中的更改是临时的,没有对数据进行永久更改。例如,CASE 函数可以在 state 列中有 CA 值的行的查询结果集内显示 California。
SQL交叉表的实现
SQL交叉表的实现CASE 函数包含: 
SQL交叉表的实现
SQL交叉表的实现        CASE 关键字。
SQL交叉表的实现
SQL交叉表的实现
SQL交叉表的实现        需要转换的列名称。
SQL交叉表的实现
SQL交叉表的实现
SQL交叉表的实现        指定要搜索的表达式的 WHEN 子句和指定要替换它们的表达式的 THEN 子句。
SQL交叉表的实现
SQL交叉表的实现
SQL交叉表的实现        END 关键字。
SQL交叉表的实现
SQL交叉表的实现
SQL交叉表的实现        可选的、定义 CASE 函数别名的 AS 子句。 
SQL交叉表的实现


        由此,我们得出以上问题的解法:
SQL交叉表的实现SELECT  FItemID, ( CASE  FName  WHEN   ' 生产部 '   THEN  FAuxQty  ELSE   0   END AS   ' 生产部 '
SQL交叉表的实现      (
CASE  FName  WHEN   ' 包装车间 '   THEN  FAuxQty  ELSE   0   END AS   ' 包装车间 '
SQL交叉表的实现      FStockID, FDeptID
SQL交叉表的实现
FROM  testtable

        以上只是个简单的示例,只要我们理解的CASE函数的正确用法,要写出复杂的交叉表,也是轻而易举的事了。

              转载请注明作者:cnblogs(Bonny.wong) 2005.1.22