Zum Inhalt springen

PostGreSQL 7.2 create function und declare


gurkenpapst

Empfohlene Beiträge

Hallo,

hab da gerade nen kleinen Hänger und komme nicht weiter. Ich möchte innerhalb einer Funktion einen cursor auf einen Wert setzen. Nun bekomme ich immer die Fehlermeldung das ich dies innehalb einer Transaktion machen soll, allerdings ist das ganze innerhalb einer Transaktion...

CREATE OR REPLACE FUNCTION f_add_reply(int,int,int,text,text)

RETURNS integer

AS '

BEGIN;

DECLARE var_root_id CURSOR FOR SELECT root_id FROM beitraege WHERE id = $1 FOR READ ONLY;

UPDATE beitraege SET lft = lft + 2 WHERE root_id = var_root_id 

AND lft > (SELECT rgt FROM beitraege WHERE id = $1) AND rgt >= (SELECT rgt FROM beitraege WHERE id = $1);

UPDATE beitraege SET rgt = rgt + 2 WHERE root_id = (SELECT root_id FROM beitraege WHERE id = $1) 

AND rgt >= (SELECT rgt FROM beitraege WHERE id = $1);

INSERT INTO beitraege (root_id,lft,rgt,forum,creator,subject,content) VALUES 

((SELECT root_id FROM beitraege WHERE id = $1),(SELECT rgt FROM beitraege WHERE id = $1),

(SELECT rgt + 1 FROM beitraege WHERE id = $1),$2,$3,$4,$5);

COMMIT;

SELECT 1 AS ignore_this;

'

LANGUAGE SQL;

Den Cursor brauche ich um die Subselects zu ersetzten, da sie zwar funktionieren, mir aber nicht die Werte liefern die ich brauche...

gruss und Danke, gurkenpapst

Link zu diesem Kommentar
Auf anderen Seiten teilen

Dein Kommentar

Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...