程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程綜合問答 >> sql列行轉換-求助:sql 列變行,列對多列的問題

sql列行轉換-求助:sql 列變行,列對多列的問題

編輯:編程綜合問答
求助:sql 列變行,列對多列的問題

現在數據結構 如下圖
圖片說明

要變成
圖片說明
求大神 方法!
網上看到的方法:
declare @sql varchar(8000)
set @sql = 'select 名稱 ,規格'
select @sql = @sql + ', max(case 供應商 when ''' + 供應商 + ''' then 重量 else 0 end) [' + 供應商 + ']'
from (select distinct 供應商 from #tb) as a
set @sql = @sql + ' from #tb group by 名稱 ,規格'
exec(@sql)

但數量怎麼出來?

最佳回答:


 create table 表(
  供應商 varchar(20),
  名稱 varchar(20),
  規格 varchar(20),
  數量 int,
  重量 int
);
insert into 表(供應商,名稱,規格,數量,重量) values('A','名1','規格1',1,2);
insert into 表(供應商,名稱,規格,數量,重量) values('B','名2','規格2',1,3);
insert into 表(供應商,名稱,規格,數量,重量) values('B','名1','規格1',1,2);
insert into 表(供應商,名稱,規格,數量,重量) values('C','名3','規格3',1,4);

SELECT 名稱,規格
,SUM(CASE 供應商 WHEN 'A' then 數量 else 0 end) A數量
,SUM(CASE 供應商 WHEN 'A' then 重量 else 0  end) A重量
,SUM(CASE 供應商 WHEN 'B' then 數量 else 0  end) A數量
,SUM(CASE 供應商 WHEN 'B' then 重量 else 0  end) A重量
,SUM(CASE 供應商 WHEN 'C' then 數量 else 0  end) A數量
,SUM(CASE 供應商 WHEN 'C' then 重量 else 0  end) A重量
FROM 表 group by 名稱,規格
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved