CREATION_DATE REJECTED_REASON PART_NAME REJECTED_QTY
03-03-2014 Metal chips in port face PEGEOUT 1.8 CYLINDER HEAD CASTING H29 15
03-03-2014 Angular hole Shrinkage PEGEOUT 1.8 CYLINDER HEAD CASTING H29 7
01-05-2014 5th cap side dross CYL.HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA 23
01-05-2014 Casting broken CYL.HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA 3
01-05-2014 Bend in dand CYL . HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA 11
01-05-2014 Bend in casting CYL . HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA 17
07-05-2014 Angular hole Shrinkage EATON REAR HOUSING H-99 10
08-05-2014 Unclean CASTING CYLINDER HEAD 01 OF KOHLER H-185 9
08-05-2014 Angular hole Shrinkage CASTING CYLINDER HEAD 01 OF KOHLER H-185 1
08-05-2014 Bend CASTING CYLINDER HEAD 01 OF KOHLER H-185 20
12-11-2014 Shrinkage on top face GEAR BOX HOUSING ITL CLUTCH - ITL 15
12-11-2014 Casting damage GEAR BOX HOUSING ITL CLUTCH - ITL 5
13-11-2014 1st Exhaust Port Core Shift PIAGGIO 3 VALVE CYLINDER HEAD CASTING 22
06-01-2015 Shrinkage in spark plug G-30 CYLINDER HEAD REAR CASTING 14
08-01-2015 1st cap side dross G-30 CYLINDER HEAD REAR CASTING 6
08-01-2015 Unclean G-30 CYLINDER HEAD REAR CASTING 2
08-01-2015 Shrinkage in spark plug G-30 CYLINDER HEAD REAR CASTING 12
13-01-2015 1st cap side dross G-30 CYLINDER HEAD REAR CASTING 1
13-01-2015 1st Exhaust Port Core Shift G-30 CYLINDER HEAD REAR CASTING 9
13-01-2015 Shrinkage in spark plug G-30 CYLINDER HEAD REAR CASTING 10
假设我在特定表格中有上述值。现在我需要将拒绝数量和显示拒绝原因作为列和拒绝数量作为月份和分段值进行总结 假设我需要2014年5月的数据。上面的值列表的报告输出应该是: -
PART NAME 5th cap side dross Casting Broken Bend in Casting Bend in Dand Angular Hole Shrinkage Unclean Bend
CYL . HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA 23 3 17 11 0 0 0
CASTING CYLINDER HEAD 01 OF KOHLER H-185 0 0 0 0 1 9 20
EATON REAR HOUSING H-99 0 0 0 0 10 0 0
请帮助我并指导我通过sql或pl sql在oracle中实现此任务。
答案 0 :(得分:0)
试试这个:
SELECT *
FROM your_table_name
PIVOT (COUNT(REJECTED_REASON)
FOR REJECTED_REASON IN('reason1', 'reason2', 'reason3' ....))
;
答案 1 :(得分:0)
Aramillo说,最好是使用动态支点。 Oracle有类似的东西,它是 pivot xml 子句,但我有一些查询,无需xml操作即可动态完成工作。如你所说,你只需要显示报告,所以在一些格式化后,下面的查询输出将适合你的情况:
select part_name ,
rtrim(xmlagg(xmlelement(e,rejected_reason,',').extract('//text()')),',')
|| chr(10) /*new line char */ ||
rtrim(xmlagg(xmlelement(e,cnt,',').extract('//text()')),',')
from (
select part_name,
rejected_reason,
row_number() over (partition by part_name, rejected_reason order by rejected_reason) as rn,
count(*) over (partition by part_name, rejected_reason order by rejected_reason) as cnt
from your_table
order by part_name,
rejected_reason
)
where data_column = 'MAY 2014'
and rn = 1 -- to avoid duplicates in groups
group by part_name;
答案 2 :(得分:0)
请复制/粘贴以查看结果。
SELECT part_name
, sum(decode(reject_reason, 'Metal chips in port face', 1, 0)) "Metal chips in port face"
, sum(decode(reject_reason, 'Angular hole Shrinkage', 1, 0)) "Angular hole Shrinkage"
, sum(decode(reject_reason, '5th cap side dross', 1, 0)) "5th cap side dross"
, sum(decode(reject_reason, 'Casting broken', 1, 0)) "Casting broken"
, sum(decode(reject_reason, 'Bend in dand', 1, 0)) "Bend in dand"
, sum(decode(reject_reason, 'Bend in casting', 1, 0)) "Bend in casting"
FROM
(
SELECT '03-03-2014' create_date, 'Metal chips in port face' reject_reason,'PEGEOUT 1.8 CYLINDER HEAD CASTING H29' part_name FROM dual
UNION ALL
SELECT '03-03-2014', 'Angular hole Shrinkage', 'PEGEOUT 1.8 CYLINDER HEAD CASTING H29' FROM dual
UNION ALL
SELECT '01-05-2014', '5th cap side dross', 'CYL. HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA' FROM dual
UNION ALL
SELECT '01-05-2014', '5th cap side dross', 'CYL. HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA' FROM dual
UNION ALL
SELECT '01-05-2014', 'Casting broken' , 'CYL. HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA' FROM dual
UNION ALL
SELECT '01-05-2014', 'Bend in dand', 'CYL. HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA' FROM dual
UNION ALL
SELECT '01-05-2014', 'Bend in casting', 'CYL. HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA' FROM dual
)
GROUP BY part_name
ORDER BY 1, 3
/
OR
SELECT part_name
, MAX(CASE WHEN reject_reason = 'Metal chips in port face' THEN cnt END) "Metal chips in port face"
, MAX(CASE WHEN reject_reason = 'Angular hole Shrinkage' THEN cnt END) "Angular hole Shrinkage"
, MAX(CASE WHEN reject_reason = '5th cap side dross' THEN cnt END) "5th cap side dross"
, MAX(CASE WHEN reject_reason = 'Casting broken' THEN cnt END) "Casting broken"
, MAX(CASE WHEN reject_reason = 'Bend in dand' THEN cnt END) "Bend in dand"
, MAX(CASE WHEN reject_reason = 'Bend in casting' THEN cnt END) "Bend in casting"
FROM (
SELECT part_name
, reject_reason
, count(*) over (partition by part_name, reject_reason order by reject_reason) as cnt
FROM (
SELECT '03-03-2014' create_date, 'Metal chips in port face' reject_reason, 'PEGEOUT 1.8 CYLINDER HEAD CASTING H29' part_name FROM dual
UNION ALL
SELECT '03-03-2014', 'Angular hole Shrinkage', 'PEGEOUT 1.8 CYLINDER HEAD CASTING H29' FROM dual
UNION ALL
SELECT '01-05-2014', '5th cap side dross', 'CYL. HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA' FROM dual
UNION ALL
SELECT '01-05-2014', '5th cap side dross', 'CYL. HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA' FROM dual
UNION ALL
SELECT '01-05-2014', 'Casting broken' , 'CYL. HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA' FROM dual
UNION ALL
SELECT '01-05-2014', 'Bend in dand', 'CYL. HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA' FROM dual
UNION ALL
SELECT '01-05-2014', 'Bend in casting', 'CYL. HEAD VM MOTORI-4 CYL TESTA CILINDRI LAVORATA' FROM dual
))
GROUP BY part_name
ORDER BY 1
/