次のデータについて、SQL で完了率の列を取得しようとしています。これは私のクエリの結果です。
work_order_no status orderqty complete precentcomplete
WO-000076 Approved 20.0000 9 5201725
WO-000076 Approved 20.0000 10 15605175
WO-000078 Approved 12000.0000 200 91258.3333333333
WO-000078 Approved 12000.0000 500 228145.833333333
私が必要とするのは、2行の結果です。行 1 は WO-00076 で、完了率です。行 2 は WO-000078 で、完了率です。以下は、私が取り組んでいるクエリです。
Select distinct wo.work_order_no,
wos.status_description,
wo.order_qty as [ORDERQTY],
p.good_tot_diff as [COMPLETE],
(sum(p.good_tot_diff)/wo.order_qty) * 100 as [PERCENTCOMPLETE]
from wo_master as wo,
process as p,
wo_statuses as wos,
so_children as soc,
so_sales_orders as sos,
cs_customers as csc
where wo.work_order_no = p.entry_18_data_txt
and wo.work_order_no = soc.work_order_no
and wo.wo_status_id = wos.wo_status_id
and wo.mfg_building_id = @buildid
and wos.wo_status_id = @statusid
group by wo.work_order_no, wos.status_description, wo.order_qty, p.good_tot_diff
だから私は結果が以下のようになることを望みます
work_order_no status orderqty complete precentcomplete
WO-000076 Approved 20.0000 19 0.95
WO-000078 Approved 12000.0000 700 0.005