请大家SQL行转列如何实现这个值是字符串的

mfkpie 2017-04-13 09:22:34
SQL行转列

select * from sysobjects where [xtype]='u'
go
if exists(select id from sysobjects where name='work_order_wo')
drop table work_order_wo--删除与实验冲突的表
go
create table work_order_wo--创建工序表
(
[id] int identity(1,1),
[name] nvarchar(20) not null,
subject nvarchar(20) not null,
order nvarchar(20) not null
)
go

select * from work_order_wo
go

--添加实验数据
insert work_order_wo values ('张三','工序1','打磨');
insert work_order_wo values ('张三','工序2','打磨2');
insert work_order_wo values ('张三','工序3','打磨3');
insert work_order_wo values ('李四','工序1','冲压');
insert work_order_wo values ('李四','工序2','冲压2');
insert work_order_wo values ('王五','工序1','冲压2');

go
select * from work_order_wo
go

想要的结果为

姓名 工序1 工序2 工序3
张三 打磨 打磨2 打磨3
李四 冲压 冲压2
王五 冲压2

这种的行转列想用在SQL 2000的动态方式要如何解决呢。。。

SQL 2000 只能使用视图来调用函数

能写成函数 然后使用视图来调用这个
...全文
1765 7 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
中国风 2018-01-26
  • 打赏
  • 举报
回复
用以下方法测测 e.g.
DECLARE @Sql NVARCHAR(4000)
SET @Sql=''
SELECT @Sql=@Sql+','+QUOTENAME(subject)+'=max(CASE WHEN subject='+QUOTENAME(subject,'''')+' THEN [order] END)' FROM work_order_wo GROUP BY subject

EXEC('SELECT [name] '+@Sql+'FROM work_order_wo GROUP BY [name] ')
/*
name	工序1	工序2	工序3
李四	冲压	冲压2	NULL
王五	冲压2	NULL	NULL
张三	打磨	打磨2	打磨3
*/
a2048 2018-01-18
  • 打赏
  • 举报
回复
如果工序固定这几个2楼的答案不错。
二月十六 版主 2018-01-18
  • 打赏
  • 举报
回复
引用 4 楼 p474391654 的回复:
[quote=引用 1 楼 sinat_28984567 的回复:]
DECLARE @sql VARCHAR(8000)
SET @sql = 'select Name as ' + '姓名'
SELECT  @sql = @sql + ' , max(case Subject when ''' + Subject
        + ''' then [order]  else null end) [' + Subject + ']'
FROM    ( SELECT DISTINCT
                    Subject
          FROM      work_order_wo
        ) AS a
SET @sql = @sql + ' from work_order_wo group by name'
EXEC( @sql ) 

我试了这样写不行,[Err] 22018 - [SQL Server]在将 varchar 值 '' then [content] else null end) [' 转换成数据类型 int 时失败。[/quote] 得看具体数据是什么
p474391654 2018-01-18
  • 打赏
  • 举报
回复
引用 1 楼 sinat_28984567 的回复:
DECLARE @sql VARCHAR(8000)
SET @sql = 'select Name as ' + '姓名'
SELECT  @sql = @sql + ' , max(case Subject when ''' + Subject
        + ''' then [order]  else null end) [' + Subject + ']'
FROM    ( SELECT DISTINCT
                    Subject
          FROM      work_order_wo
        ) AS a
SET @sql = @sql + ' from work_order_wo group by name'
EXEC( @sql ) 

我试了这样写不行,[Err] 22018 - [SQL Server]在将 varchar 值 '' then [content] else null end) [' 转换成数据类型 int 时失败。
xiaoxiangqing 2017-04-13
  • 打赏
  • 举报
回复
网上有很多现成的方法
0与1之间 2017-04-13
  • 打赏
  • 举报
回复
create table work_order_wo--创建工序表 ( [id] int identity(1,1), [name] nvarchar(20) not null, [subject] nvarchar(20) not null, [order] nvarchar(20) not null ) go select * from work_order_wo go --添加实验数据 insert [work_order_wo] values ('张三','工序1','打磨'); insert [work_order_wo] values ('张三','工序2','打磨2'); insert [work_order_wo] values ('张三','工序3','打磨3'); insert [work_order_wo] values ('李四','工序1','冲压'); insert [work_order_wo] values ('李四','工序2','冲压2'); insert [work_order_wo] values ('王五','工序1','冲压2'); go SELECT [name], max(CASE [subject] WHEN'工序1' THEN [order] ELSE Null END) 工序1, max(CASE [subject] WHEN'工序2' THEN [order] ELSE Null END) 工序2, max(CASE [subject] WHEN'工序3' THEN [order] ELSE Null END) 工序3 FROM [work_order_wo] GROUP BY [name]
二月十六 版主 2017-04-13
  • 打赏
  • 举报
回复
DECLARE @sql VARCHAR(8000)
SET @sql = 'select Name as ' + '姓名'
SELECT @sql = @sql + ' , max(case Subject when ''' + Subject
+ ''' then [order] else null end) [' + Subject + ']'
FROM ( SELECT DISTINCT
Subject
FROM work_order_wo
) AS a
SET @sql = @sql + ' from work_order_wo group by name'
EXEC( @sql )




34,837

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧