maze13
Goto Top

sql-update in abhängigkeit eines Wertes in einer anderen Tabelle

Hallo alle zusammen,

ich habe eine Frage zu einem update-statement.

ich würde gerne etwas machen in der art:

update tab1
case wert.tab2
when 100 set wert.tab1 = 1
when 200 set wert.tab1 = 2
end
where
tab1.id = tab2.id

es soll also ein wert aus tab1 in abhängigkeit des wertes in tab2 verändert werden. Da ich tab2 aber nirgendwo bekannt mache, läuft das script
auf einen Fehler. An welcher stelle kann ich Tabelle 2 noch in das update-statement einbauen?

Vielen Dank, ihr würder mir sehr helfen!

Viele Grüße, Maze

Content-ID: 110220

Url: https://administrator.de/contentid/110220

Ausgedruckt am: 22.11.2024 um 19:11 Uhr

nxclass
nxclass 28.02.2009 um 17:46:42 Uhr
Goto Top
unterstützt deine Datenbank Variablen ? - dann versuch es doch mal damit:
SET @var = (SELECT CASE wert WHEN 100 THEN 1 WHEN 200 THEN 2 END FROM ... );
UPDATE tabelle SET wert = @var WHERE ... ;

.. oder evtl. mit einer unter Abfrage:
UPDATE tabelle (spalte, ..) SELECT ...

UPDATE tabelle SET spalte = (SELECT ... ) WHERE ...
Maze13
Maze13 01.03.2009 um 11:11:50 Uhr
Goto Top
Hi nxclass,

danke für Deine Antwort!

Stimmt, das mit der Variable müsste eigentlich funktionieren. Das Problem ist nur das die @var durch die select-Abfrage mehrere Werte (auf einmal) enthalten würde, die man dann erstmal wieder aufsplitten müsste um sie für das update-statement verwenden zu können. Besser wäre
es wahrscheinlich, das ganze in eine Art Schleife zu packen, aber das habe ich mit SQL auch noch nicht gemacht.

Das zweite Bsp. mit der Unterabfrage habe ich nicht ganz verstanden. Insbesondere das SELECT in der ersten Zeile. In der 3. Zeile fehlt dann noch die CASE-Anweisung, aber im Prinzip ist es dann das gleiche wie mit der Variable, würde ich sagen ...

Also, noch mal danke für Deine Hinweise!

Viele Grüße, Maze
nxclass
nxclass 01.03.2009 um 16:39:42 Uhr
Goto Top
ok - 2. Beispiel 1. Zeile : falscher Syntax !

in der 3. Zeile:
zu beachten ist das die innere SELECT Anweisung nur ein Feld und eine Zeile zurückgeben darf. - Also genau das was Du schon ganz oben in deine UPDATE Anweisung eingetragen hast.
UPDATE tabelle SET
  spalte = (
    SELECT
      CASE wert.tab2
        WHEN 100 THEN 1 
        WHEN 200 THEN 2
      END AS 'wert'  
    FROM tab1, tab2
    WHERE tab1.id = tab2.id
    LIMIT 1
  )
WHERE ...

.. habe mir nochmal deine Beschreibung von ganz oben durchgelesen - und glaube Du wirst nicht umher kommen das in eine Schleife zu packen - entweder in deinem Script oder in SQL.

evtl. könnte das auch eine Alternative sein !? :
UPDATE tab1 SET spalte = 1 WHERE id IN (SELECT id FROM tab2 WHERE wert = 100 );
UPDATE tab1 SET spalte = 2 WHERE id IN (SELECT id FROM tab2 WHERE wert = 200 );
Maze13
Maze13 01.03.2009 um 18:05:30 Uhr
Goto Top
Hi nxclass,

ja, die letztgenannte Alternative sollte wohl klappen. Ich wollte das eigentlich umgehen, da es in Wirklichkeit doch ein paar mehr als 2 "CASES" sind ...

Falls Dir noch ne passende Schleife einfällt, würde ich mich natürlich freuen, ansonsten mache ich es wie oben beschrieben.

Nochmal schönen Dank!
nxclass
nxclass 01.03.2009 um 22:26:36 Uhr
Goto Top
nun ja - wenn es rel. viele mögliche 'wert' Werte gibt könnte man eine 'Mapper' Tabelle anlegen.

mapper
wert neuer_wert
100 1
200 2
... diese Tabelle könnte auch nur temp. angelegt werden.