Замена / Оценка вложенного запроса со значением NULL |Oracle SQL - PullRequest
0 голосов
/ 26 октября 2018

Я использую следующий запрос, и я прошу прощения, если это немного грязно, это единственный способ, которым я мог получить это, чтобы дать мне результаты, которые я хотел :) Но в самом левом столбце «PO», когда все это сказано и сделано тамявляется единственным экземпляром (null), см. пример вывода.Это приводит к тому, что числовые значения отображаются как (ноль), когда я могу подтвердить, что они должны иметь значения.

Я использовал функции NVL, NVL2, COALESCE безуспешно.

select query2.PO, query2.Work_Group, query2.PO_QTY_TO_Move, query8.Active_Pick_Faces AS Active_Pick_Faces, query4.C0R_Qty_To_Move AS Move_C0R, query6.NA_Qty_To_Move AS Move_NA
from((select PO, Work_Group, SUM(qty_to_move) AS PO_Qty_To_Move
        from(select order_header.purchase_order AS PO,order_header.work_group AS Work_Group, move_task.task_id, move_task.qty_to_move AS qty_to_move
                from order_header
                left join move_task
                on order_header.order_id = move_task.task_id
                where move_task.site_id = 'USCOL1' and move_task.client_id = 'SDRY-US' and move_task.status != 'Consol' )query1
        group by PO, Work_Group)query2
    left join
        (select PO, Work_Group, SUM(qty_to_move) AS C0R_Qty_To_Move
        from(select order_header.purchase_order AS PO,order_header.work_group AS Work_Group, move_task.task_id, move_task.from_loc_id, move_task.qty_to_move AS qty_to_move
                from order_header
                left join move_task
                on order_header.order_id = move_task.task_id
                left join location
                on move_task.from_loc_id = location.location_id
                where move_task.site_id = 'USCOL1' and move_task.client_id = 'SDRY-US' and location.work_zone = 'C0-R' and move_task.status != 'Consol' or order_header.purchase_order is null)query3
        group by PO, Work_Group)query4
    on query2.PO = query4.PO
    left join 
        (select PO, Work_Group, SUM(qty_to_move) AS NA_Qty_To_Move
        from(select order_header.purchase_order AS PO,order_header.work_group AS Work_Group, move_task.task_id, move_task.qty_to_move AS qty_to_move
                from order_header
                left join move_task
                on order_header.order_id = move_task.task_id
                where move_task.site_id = 'USCOL1' and move_task.client_id = 'SDRY-US' and move_task.from_loc_id like 'NA%' and move_task.from_loc_id not like '%PAL%' and move_task.status != 'Consol' )query5
        group by PO, Work_Group) query6
    on query2.PO = query6.PO
    left join 
        (select PO, Work_Group, SUM(qty_to_move) AS Active_Pick_Faces 
        from(select order_header.purchase_order AS PO,order_header.work_group AS Work_Group, move_task.task_id, move_task.qty_to_move AS qty_to_move
                from order_header
                left join move_task
                on order_header.order_id = move_task.task_id
                left join location
                on move_task.from_loc_id = location.location_id
                where move_task.site_id = 'USCOL1' and move_task.client_id = 'SDRY-US' and location.work_zone in ('C0S','C0S2','LAUNCH','C0-RPALLET', 'TRANSIT')and move_task.status != 'Consol' or move_task.from_loc_id like '%PAL%')query7
        group by PO, Work_Group) query8
    on query2.PO = query8.PO)

Пример вывода

1 Ответ

0 голосов
/ 26 октября 2018

Вы используете условия соединения, такие как:

on query2.PO = query8.PO

но null никогда не равен (или не равен) чему-либо еще, поэтому, если PO равно нулю, вы не можете использовать проверку на равенство; вам нужно использовать is null. Как вы хотите проверить оба, вы можете сделать:

on query2.PO = query8.PO
or (query2.PO is null and query8.PO is null)

Подробнее в документации .

...