Función Oracle Lag con parámetro dinámico
Tengo un problema especifico Tengo una tabla que contiene valores no válidos. Necesito reemplazar los valores no válidos (aquí0
) con el valor anterior que es mayor que0
.
La dificultad es que no es apropiado para mí usar una actualización o un inserto (el cursor y la actualización lo harían). Bueno, mi única forma es usar una instrucción Select.
Cuando uso ellag(col1, 1)
- funciono con mayúsculas y minúsculas, solo obtengo una columna con el valor correcto.
select col1, col2 realcol2,
(case
when col2 = 0 then
lag(col2,1,1) over (partition by col1 order by col1 )
else
col2
end ) col2,
col3 realcol3,
(case
when col3 = 0 then
lag(col3,1,1) over (partition by col1 order by col1 )
else
col3
end ) col3
from test_table
Contenido deTEST_TABLE
:
---------------------------
Col1 | Col2 | Col3 | Col4
---------------------------
A | 0 | 1 | 5
B | 0 | 4 | 0
C | 2 | 0 | 0
D | 0 | 0 | 0
E | 3 | 5 | 0
F | 0 | 3 | 0
G | 0 | 3 | 1
A | 0 | 1 | 5
E | 3 | 5 | 0
Resultado esperado de la consulta:
---------------------------
Col1 | Col2 | Col3 | Col4
---------------------------
A | 0 | 1 | 5
B | 0 | 4 | 5
C | 2 | 4 | 5
D | 2 | 4 | 5
E | 3 | 5 | 5
F | 3 | 3 | 5
G | 3 | 3 | 1
A | 3 | 1 | 5
E | 3 | 5 | 5