select id, part_no, sq2-oq2 rest
from (
select tr.*, row_number() over (partition by part_no order by id) rnk
from (select i.transaction_equipmentid id, part_no, i.quantity iq,
sum(i.quantity) over (partition by part_no
order by i.transaction_equipmentid) sq1,
sum(i.quantity) over (partition by part_no) sq2,
o.quantity oq1,
max(o.quantity) over (partition by part_no) oq2
from wa_ii_tbl_tr_equipment i
left join wa_ii_tbl_tr_out_equipment o
on o.transaction_equipmentid_fk = i.transaction_equipmentid
where i.supplierid_fk = 62551 ) tr
where sq1 >= oq2 or oq2 is null )
where rnk = 1
मैं इनपुट और आउटपुट में शामिल होता हूं, फिर विश्लेषणात्मक कार्यों का उपयोग करता हूं sum()
और max()
मैं सभी आवश्यक सूचनाएं तैयार करता हूं, सबसे महत्वपूर्ण संचयी योग है। आप इसे सबसे आंतरिक क्वेरी को अलग से चलाते हुए देख सकते हैं, इसे tr
. के रूप में उपनामित किया गया है .
अगला चरण केवल जोड़ना है row_number()
पहली पंक्ति (पंक्तियों) को खोजने के लिए जहां इनपुट आउटपुट से अधिक है और इस पंक्ति और शेष अंतर को दिखाएं।
यह शर्त:or oq2 is null
अन्य भागों को भी दिखाने के लिए आवश्यक है (यहां PA000535
)।
कृपया विश्लेषणात्मक कार्यों के बारे में पढ़ें, नेट पर कई ट्यूटोरियल हैं।
परीक्षण डेटा:
create table WA_II_TBL_TR_EQUIPMENT(
TRANSACTION_EQUIPMENTID varchar2(15), DESCRIPTION varchar2(10),
SUPPLIERID_FK number(6), PART_NO varchar2(10), QUANTITY number(6));
insert into WA_II_TBL_TR_EQUIPMENT values ('TE201708000002', 'fg', 62551, 'GSDFGSG', 2);
insert into WA_II_TBL_TR_EQUIPMENT values ('TE201709000003', 'fg', 62551, 'PA000535', 7);
insert into WA_II_TBL_TR_EQUIPMENT values ('TE201709000002', 'fg', 62551, 'GSDFGSG', 9);
insert into WA_II_TBL_TR_EQUIPMENT values ('TE201708000004', 'fg', 62551, 'GSDFGSG', 10);
insert into WA_II_TBL_TR_EQUIPMENT values ('TE201708000003', 'fg', 62551, 'GSDFGSG', 2);
insert into WA_II_TBL_TR_EQUIPMENT values ('TE201709000001', 'Test', 48544, 'Test', 8);
create table WA_II_TBL_TR_OUT_EQUIPMENT(
TRANSACTION_OUT_EQUIPMENTID varchar2(15),
TRANSACTION_EQUIPMENTID_FK varchar2(15),
QUANTITY number(6));
insert into WA_II_TBL_TR_OUT_EQUIPMENT values('TOE201709000001', 'TE201708000002', 3);
आउटपुट:
ID PART_NO REST
--------------- ---------- ----------
TE201708000003 GSDFGSG 20
TE201709000003 PA000535