Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

PostGreSQL 7.2 create function und declare

Empfohlene Antworten

Veröffentlicht

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

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.