游标实例行转列

 
alter proc SP_Cut_CutBundNoList
as 
begin


declare @MoNO VARCHAR(100)
declare @CutLotNo int


select MONo,CutLotNo,GarPart,ColorName,
BundNo,SizeName,Qty into #cutd
 from tCutD  where MONo='1631040011' and CutLotNo in(6,7,8,9,10,11,12,13,26,27)
 
 --select * from #cutd
-- drop table #SizeOrder


select DIstinct ColorName  into #CutColor from #cutd
SELECT DISTINCT SizeName into #CutSize  FROM #cutd
select ROW_NUMBER() over(order by  SizeName ) as SizeID, SizeName into #SizeOrder from #CutSize




select ColorName,SizeName,SUM(Qty) AS 'Qty'
into #CutCOlorQty from #cutd
GROUP BY ColorName,SizeName






declare @SizeID Int 
declare @SizeName varchar(50)
declare @sql varchar(300)
declare @AdName varchar(100)


set @SizeName='';
set @SizeID=0;
set @sql='';
set @AdName='';


Declare  chimayoubiao  Cursor for select sizeName from  #SizeOrder order by sizeID for read only;
open chimayoubiao
fetch next from  chimayoubiao into @SizeName;

while @@FETCH_STATUS =0 
begin
set @AdName='size'+@sizeName;
set @sql='alter table #CutColor add '+@AdName+' varchar(50) default(0);';
  exec(@sql);
  print @sql;
  set @sql='update #CutColor set '+@AdName+'= q.Qty 
  from #CutColor C join #CutCOlorQty Q on c.ColorName=Q.ColorName
  and SUBSTRING(''c.'+@AdName+''',7,100)  =Q.SizeName';
  Exec(@sql);
 
  set @sql=' update #CutColor set '+ @AdName +'=0 where '+ @AdName +' is null';
  Exec(@sql);
  fetch next from chimayoubiao into @sizeName;
end;

-----SP_Cut_CutBundNoList

select * from #CutColor;
close chimayoubiao;
deallocate chimayoubiao

truncate table #CutCOlorQty;
truncate table #SizeOrder;
truncate table #CutSize;
truncate table #CutColor;
truncate table #cutD ;

drop  table #CutCOlorQty;
drop  table #SizeOrder;
drop  table #CutSize;
drop  table #CutColor;
drop  table #cutD ;
 

end;

结果如下:



原始数据如下:









  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

屎涂行者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值