Zurückgeben einer Zeile aus einer Mit-Klausel
-
04-10-2019 - |
Frage
Ich versuche, eine Funktion zu machen, die einen Wert Retruns.
In meiner Funktion Ich habe dieses Skript:
WITH t_new AS
(
SELECT PersIDOLD, PersIDNEW, RightsMUT,
SUM(gap) over(ORDER BY PersIDOLD, PersIDNEW) grp
FROM
(
SELECT h1.*,
CASE
WHEN h1.PersIDNEW = lag(h1.PersIDNEW)
over(ORDER BY h1.PersIDOLD, h1.PersIDNEW)
OR h1.PersIDOLD = lag(h1.PersIDOLD)
over(ORDER BY h1.PersIDOLD, h1.PersIDNEW)
THEN 0
ELSE 1
END gap
FROM HelpTable1 h1
)
)
SELECT PERSIDNEW, RIGHTSMUT
FROM t_new
WHERE grp =
(
SELECT grp FROM t_new WHERE PersIDNEW = 12 -- going to be a variable
)
ist die Rückkehr wie folgt aus:
http://img59.imageshack.us/img59/6733/tablei.gif
Jetzt will ich row 3
coze zurückkehren es hat eine 1
in Reihe RightsMUT
Wie kann ich das tun?
Ich versuchte es mit 2 With
zu tun, aber Oracle nicht unterstützt 2 mit noch.
Lösung 2
Meine Lösung:
WITH t_new AS
(
-- Alles durch gehen und
SELECT PersIDOLD, PersIDNEW, RightsMUT, SUM(gap) over(ORDER BY PersIDOLD, PersIDNEW) grp
FROM
(
SELECT h1.*,
CASE
WHEN h1.PersIDNEW = lag(h1.PersIDNEW) over(ORDER BY h1.PersIDOLD, h1.PersIDNEW)
OR h1.PersIDOLD = lag(h1.PersIDOLD) over(ORDER BY h1.PersIDOLD, h1.PersIDNEW)
THEN 0
ELSE 1
END gap
FROM LUTAXKT.HILFSTABELLE1UMSETZUNG h1
--WHERE h1.updateflag = 0
)
)
SELECT PersIDNEW, RightsMUT
FROM t_new
WHERE RightsMUT = 1 and
grp =
(
SELECT grp FROM t_new WHERE PersIDNEW = 12
)
Andere Tipps
Lassen Sie mich versuchen zu erraten - pls überprüfen, ob die Folgenden finden Sie, was Sie brauchen:
WITH t_new AS
(
SELECT PersIDOLD, PersIDNEW, RightsMUT,
SUM(gap) over(ORDER BY PersIDOLD, PersIDNEW) grp
FROM
(
SELECT h1.*,
CASE
WHEN h1.PersIDNEW = lag(h1.PersIDNEW)
over(ORDER BY h1.PersIDOLD, h1.PersIDNEW)
OR h1.PersIDOLD = lag(h1.PersIDOLD)
over(ORDER BY h1.PersIDOLD, h1.PersIDNEW)
THEN 0
ELSE 1
END gap
FROM HelpTable1 h1
)
)
SELECT PERSIDNEW, RIGHTSMUT
FROM t_new
WHERE PersIDNEW = 12 AND RightsMUT = 1
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow