Zum Inhalt springen

PostGreSQL 7.2 create function und declare


Empfohlene Beiträge

Geschrieben

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

Geschrieben

Der Fehler lag an dem LANGUAGE am Ende.

Die verwendete Sprache war natürlich plpgsql, und nicht nur SQL, konnte also so nicht funktionieren, hatte nur den Fehler ständig überlesen...

Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren

Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können

Benutzerkonto erstellen

Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!

Neues Benutzerkonto erstellen

Anmelden

Du hast bereits ein Benutzerkonto? Melde Dich hier an.

Jetzt anmelden

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...