设计天下吧 关注:251贴子:4,067
  • 0回复贴,共1

用SQL SERVER 2005新提供的命令实现行列转换

只看楼主收藏回复

一朋友问一个问题,需要将一张表里指定的编号(2-4个),按照名称统计编号的数量,仅有一个编号数据的不显示。 
  模拟表结构如下: 
  CREATE TABLE TEMP 
  ( 
   T_ID INT, 
   T_NAME NVARCHAR(5) 
  )插入一些数据: 
  INSERT TEMP SELECT 1,'A' 
  UNION ALL SELECT 2,'B' 
  UNION ALL SELECT 3,'C' 
  UNION ALL SELECT 4,'D' 
  UNION ALL SELECT 1,'C' 
  UNION ALL SELECT 4,'B' 
  UNION ALL SELECT 4,'C' 
  UNION ALL SELECT 2,'A'实际应得到的数据为: 
  T_ID1 T_ID2 T_ID3 T_ID4 T_NAME 
  ----------- ----------- ----------- ----------- ------ 
  1 1 0 0 A 
  0 1 0 1 B 
  1 0 1 1 C因为编号是给出的,那么得想办法得到符合条件的T_NAME,这样的话需要根据 T_ID和T_NAME分组数据然后将有多个编号的数据过滤出来,这里需要将结果集自连一下,变量表不可以进行JOIN操作,临时表的话我不大想在这里用,所幸SQL SERVER 2005 提供了一个新的语法 CTE(COMMON TABLE EXPRESSION)公共表表达式,不用创建临时表,并且可以进行JOIN操作,遗憾的是必须紧跟着使用,在后面的语句就不能用了.用CTE实现这个功能: 
  WITH _TEMP AS 
  ( 
   SELECT T_ID,T_NAME FROM TEMP WHERE T_ID IN (1,2,3,4) GROUP BY T_ID,T_NAME 
  ) 
  SELECT DISTINCT _TEMP.T_NAME FROM _TEMP JOIN _TEMP TEMP_TEMP 
   ON _TEMP.T_NAME=TEMP_TEMP.T_NAME WHERE _TEMP.T_ID<>TEMP_TEMP.T_ID查询的数据为: 
  T_NAME 
  ------ 
  A 
  B 
  C这样符合条件的T_NAME数据就取出来了,现在定义一个变量,将这个数据组合起来作为条件去取出符合条件的数据: 
  DECLARE @NAMES NVARCHAR(20) 
  SET @NAMES = ''; 


1楼2008-03-01 10:58回复