Eu tenho 2 tabelas nomeadas como TBL_FIBER_INV_JOBS
e TBL_FIBER_INV_JOB_PROGRESS
. Abaixo está a descrição da tabela de ambas as tabelas
TBL_FIBER_INV_JOBS (Master Table) & TBL_FIBER_INV_JOB_PROGRESS (Child Table)
TBL_FIBER_INV_JOBS (Master Table)
Name Null? Type
------------------------- -------- --------------
JOB_ID NOT NULL NUMBER
SPAN_ID NVARCHAR2(100)
LINK_ID NVARCHAR2(100)
CREATED_BY NVARCHAR2(200)
CREATED_DATE NOT NULL DATE
MAINTENANCEZONECODE NVARCHAR2(50)
MAINTENANCEZONENAME NVARCHAR2(100)
MAINT_ZONE_NE_SPAN_LENGTH NUMBER(10,4)
SPAN_TYPE NVARCHAR2(20)
JOB_FLAG NUMBER
MISSING_ABD_LENGTH NUMBER(38,10)
REOFFERFLAG VARCHAR2(10)
TBL_FIBER_INV_JOB_PROGRESS (Child Table)
Name Null? Type
---------------------- -------- --------------
JOB_PROGRESS_ID NOT NULL NUMBER
JOB_ID NUMBER
STATUS_ID NUMBER
APPROVED_BY NVARCHAR2(200)
APPROVED_DATE DATE
REJECTED_BY NVARCHAR2(200)
REJECTED_DATE DATE
APPROV_REJECT_REMARK NVARCHAR2(255)
DELAY_REASON NVARCHAR2(255)
ISABDMISSING NUMBER
HOTO_OFFERED_LENGTH NUMBER
LIT_OFFERED_LENGTH NUMBER
HOTO_ACTUAL_LENGTH NUMBER
LIT_ACTUAL_LENGTH NUMBER
ABD_COMPLETED_LENGTH NUMBER
NE_SPAN_LENGTH NUMBER(10,4)
CREATED_BY NVARCHAR2(200)
CREATED_DATE NOT NULL DATE
MODIFIED_BY NVARCHAR2(200)
MODIFIED_DATE DATE
UMS_GROUP_ASS_BY_ID NUMBER
UMS_GROUP_ASS_BY_NAME NVARCHAR2(200)
UMS_GROUP_ASS_TO_ID NUMBER
UMS_GROUP_ASS_TO_NAME NVARCHAR2(200)
UMS_GROUP_ASS_TO_DATE DATE
JOB_PROGRESS_FLAG NOT NULL NUMBER
Portanto, o caso é que pode haver vários JOB_ID
na tabela filho com unique JOB_PROGESS_ID
. Agora o que eu quero é
Um procedimento onde eu sempre quero o máximo
JOB_PROGESS_ID
dissoJOB_ID
com uma condição da tabela filho que é
Condição da tabela filho:- UMS_GROUP_ASS_BY_NAME = 'CMM'
e UMS_GROUP_ASS_TO_NAME IS NULL
. Quero apenas 3 colunas da tabela mestre, que éJOB_ID, SPAN_ID, LINK_ID
Como não consigo buscar o máximo JOB_PROGRESS_ID
para o arquivo JOB_ID
. Por favor, sugira
ATUALIZAR
Tentei com a consulta abaixo, mas não é exato o que desejo.
select max(job_progress_id),hoto_actual_length from tbl_fiber_inv_job_progress where job_id = 86753 and ums_group_ass_by_name='CMM' and ums_group_ass_to_name is null group by hoto_actual_length;
select max(job_id), span_id, job_flag,nvl(missing_abd_length,0) missing_abd_length, maint_zone_ne_span_length, maintenancezonecode from tbl_fiber_inv_jobs where job_id = 86753 and job_flag = 0 and span_type <> 'FTTX' group by span_id, job_flag,missing_abd_length, maint_zone_ne_span_length,maintenancezonecode; -- 187375
Não é uma junção (juntamente com agregação e alguns filtros)?
Ou talvez usando um CTE?
[EDIT] Você comentou que precisa de dados de outra tabela ( histórico ). Foi assim que eu entendi: