标题:用什么办法.着急
只看楼主
23760639
Rank: 1
等 级:新手上路
帖 子:277
专家分:0
注 册:2005-5-13
 问题点数:0 回复次数:1 
用什么办法.着急

我的表
工号 描述
001 电话
001 地址
001 电子邮件
002 电话
002 地址

怎么能转化成
工号 描述
001 电话,地址,电子邮件
002 电话,地址
转化成这样怎么转化 啊.

搜索更多相关主题的帖子: 办法 
2006-03-26 14:04
Tailor
Rank: 1
等 级:新手上路
帖 子:152
专家分:0
注 册:2005-6-26
得分:0 

下面的代码是可以完成的,用了游标,你如果看不懂再问吧,由于工作忙,没有怎么加注释,希望你能看懂哦.

--创建表
CREATE TABLE [TEMP] ( [GONG] [CHAR] (3) NULL , [MIAO] [VARCHAR] (10) NULL )
--插入数据
INSERT [TEMP] ( [GONG] , [MIAO] ) VALUES ( '001' , '地址' )
INSERT [TEMP] ( [GONG] , [MIAO] ) VALUES ( '001' , '电话' )
INSERT [TEMP] ( [GONG] , [MIAO] ) VALUES ( '001' , '电子邮件' )
INSERT [TEMP] ( [GONG] , [MIAO] ) VALUES ( '002' , '电话' )
INSERT [TEMP] ( [GONG] , [MIAO] ) VALUES ( '002' , '地址' )
--创建临时表
CREATE TABLE [#TEMP] ( [GONG] [CHAR] (3) NULL , [MIAO] [VARCHAR] (50) NULL )
--插入工号数据
INSERT INTO #TEMP (GONG)
SELECT DISTINCT GONG FROM TEMP

DECLARE GONGID CURSOR FOR
SELECT DISTINCT GONG FROM #TEMP
OPEN GONGID
DECLARE @CHR_GONG CHAR(3)
DECLARE @CHR_MIAO VARCHAR(30)
FETCH NEXT FROM GONGID INTO @CHR_GONG
WHILE @@FETCH_STATUS=0
BEGIN
SET @CHR_MIAO=''
SELECT @CHR_MIAO=@CHR_MIAO+MIAO+',' FROM TEMP
WHERE GONG=@CHR_GONG
UPDATE #TEMP SET MIAO=LEFT(@CHR_MIAO,LEN(@CHR_MIAO)-1)
WHERE GONG=@CHR_GONG
FETCH NEXT FROM GONGID INTO @CHR_GONG
END
CLOSE GONGID
DEALLOCATE GONGID
SELECT * FROM #TEMP
DROP TABLE #TEMP


2006-03-27 09:58



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-52913-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.439036 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved