longere 2019-12-23 14:08 采纳率: 0%
浏览 353

SQL 2008 有多列,只需要其中的两列进行列转行

订单号码 产品编号 产品名称 生产制令单号 订单数量 单位 计划生产日期 计划生产数量
GW20191127 22108004 保护膜 PL191127003 3000 pcs 2019-12-20 1000
GW20191127 22108004 保护膜 PL191127003 3000 pcs 2019-12-21 1000
GW20191127 22108004 保护膜 PL191127003 3000 pcs 2019-12-22 1000
GW20191127 22030014 双面胶 PL191130008 2000 pcs 2019-12-20 1000
GW20191127 22030014 双面胶 PL191130008 2000 pcs 2019-12-23 1000

图片说明
图片说明

下面是我写的代码,但是执行后达不到我想要的效果,如果我将计划生产日期设置为日期型,就会报错

declare @sql varchar(8000) 
set @sql = 'select 生产制令单号 ' 
select @sql = @sql + ' , max(case 计划生产日期 when ''' + 计划生产日期 + ''' then 计划生产数量 else 0 end) [' + 计划生产日期 + ']' 
from (select distinct 计划生产日期 from 生产计划表) as a 
set @sql = @sql + ' from 生产计划表 group by 生产制令单号' 
set @sql='create view v_course as ' + @sql  
print @sql exec(@sql) 
go
SELECT * FROM V_COURSE 

图片说明

  • 写回答

1条回答 默认 最新

  • 憧憬blog 2023-03-15 03:48
    关注

    首先,在你的代码中,你应该将生产制令单号也作为一个 distinct 的列,因为你要将每一个制令单号对应的日期和数量都列成一行。其次,如果你将计划生产日期设置为日期型,你需要将它用 CONVERT 转换成字符串形式,然后再对字符串进行操作。最后,你在代码中出现了 "from 生产计划表",但没有给出表的别名,因此也会导致错误。

    下面是修正后的代码:

    declare @sql varchar(8000) 
    set @sql = 'select 生产制令单号 ' 
    select @sql = @sql + ' , max(case CONVERT(varchar,计划生产日期,120) when ''' + CONVERT(varchar,计划生产日期,120) + ''' then 计划生产数量 else 0 end) [' + CONVERT(varchar,计划生产日期,120) + ']' 
    from (select distinct 生产制令单号, 计划生产日期 from 生产计划表) as a 
    set @sql = @sql + ' from 生产计划表 group by 生产制令单号' 
    set @sql='create view v_course as ' + @sql  
    print @sql exec(@sql) 
    go
    SELECT * FROM V_COURSE 
    

    希望能对你有所帮助!

    评论

报告相同问题?

悬赏问题

  • ¥15 Arcgis相交分析无法绘制一个或多个图形
  • ¥15 seatunnel-web使用SQL组件时候后台报错,无法找到表格
  • ¥15 fpga自动售货机数码管(相关搜索:数字时钟)
  • ¥15 用前端向数据库插入数据,通过debug发现数据能走到后端,但是放行之后就会提示错误
  • ¥30 3天&7天&&15天&销量如何统计同一行
  • ¥30 帮我写一段可以读取LD2450数据并计算距离的Arduino代码
  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)