Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

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

Frage Entwicklung Datenbanken

Mitglied: Maze13

Maze13 (Level 1) - Jetzt verbinden

28.02.2009, aktualisiert 01.03.2009, 8027 Aufrufe, 5 Kommentare

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
Mitglied: nxclass
28.02.2009 um 17:46 Uhr
unterstützt deine Datenbank Variablen ? - dann versuch es doch mal damit:
01.
SET @var = (SELECT CASE wert WHEN 100 THEN 1 WHEN 200 THEN 2 END FROM ... ); 
02.
UPDATE tabelle SET wert = @var WHERE ... ;
.. oder evtl. mit einer unter Abfrage:
01.
UPDATE tabelle (spalte, ..) SELECT ... 
02.
 
03.
UPDATE tabelle SET spalte = (SELECT ... ) WHERE ...
Bitte warten ..
Mitglied: Maze13
01.03.2009 um 11:11 Uhr
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
Bitte warten ..
Mitglied: nxclass
01.03.2009 um 16:39 Uhr
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.
01.
UPDATE tabelle SET 
02.
  spalte = ( 
03.
    SELECT 
04.
      CASE wert.tab2 
05.
        WHEN 100 THEN 1  
06.
        WHEN 200 THEN 2 
07.
      END AS 'wert' 
08.
    FROM tab1, tab2 
09.
    WHERE tab1.id = tab2.id 
10.
    LIMIT 1 
11.
12.
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 !? :
01.
UPDATE tab1 SET spalte = 1 WHERE id IN (SELECT id FROM tab2 WHERE wert = 100 ); 
02.
UPDATE tab1 SET spalte = 2 WHERE id IN (SELECT id FROM tab2 WHERE wert = 200 );
Bitte warten ..
Mitglied: Maze13
01.03.2009 um 18:05 Uhr
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!
Bitte warten ..
Mitglied: nxclass
01.03.2009 um 22:26 Uhr
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.
Bitte warten ..
Ähnliche Inhalte
Entwicklung
SQL Update aus derselben Tabelle
gelöst Frage von winscheilEntwicklung1 Kommentar

Hallo, ich habe folgendes Problem. Ich habe eine Tabelle die folgendermaßen aufgebaut ist. Auftrag Rechnung Position Artikel Kosten NULL ...

Datenbanken
Werte aus einer Tabelle ersetzen Werte aus einer anderen Tabelle
Frage von neotm1Datenbanken2 Kommentare

Hallo, ich versuche mit MSSQL eine Abfrage hinzubekommen, in der Werte Aus Tabelle1 Spalte2 in eine andere Tabelle schreibt, ...

Datenbanken
Spalte in einer SQL-Tabelle auslesen. Werte durch Tab getrennt!
Frage von Janekr77Datenbanken4 Kommentare

Hallo zusammen, ich habe folgende Frage. Ich möchte Werte aus einer Sql-Tabelle auslesen. Das Problem welches ich habe ist, ...

Datenbanken
Mit MS-SQL-Trigger ein Wert in eine andere Tabelle übertragen
gelöst Frage von EB-StefanDatenbanken2 Kommentare

Hallo zusammen, ich habe ein kleines Problem. Ich habe 2 Tabellen die 1:n verknüpft sind. Aufträge zu Liefertermine Es ...

Neue Wissensbeiträge
Erkennung und -Abwehr

Necur-Botnet soll Erpressungstrojaner Scarab massenhaft verbreiten

Information von BassFishFox vor 27 MinutenErkennung und -Abwehr

12,5 Millionen Spam-Mails aus einem Bot-Netz mit 6 Millionen Computern? Eigentlich eine schwache Leistung. Die Erpresser setzen dabei auf ...

Microsoft

Nadeldrucker-Problem unter Windows - Microsoft liefert Updates

Information von BassFishFox vor 56 MinutenMicrosoft

Hat ja nicht lange gedauert. Nachdem die November-Updates für Windows 7, 8.1 und 10 zahlreiche Nadeldrucker lahmgelegt hatten, stellt ...

Linux

Limux-Ende in München: Wie ein Linux Projekt unter Ausschluss der Öffentlichkeit zerstört wurde

Information von Frank vor 8 StundenLinux14 Kommentare

Mein persönlicher Kommentar zum Thema "Limux-Ende". Die SPD-Politikerin Anne Hübner hat die Richtung von München ganz klar definiert: "Wir ...

Batch & Shell

Open Object Rexx: Eine mittlerweile fast vergessene Skriptsprache aus dem Mainframebereich

Information von Penny.Cilin vor 1 TagBatch & Shell9 Kommentare

Ich kann mich noch sehr gut an diese Skriptsprache erinnern und nutze diese auch heute ab und an noch. ...

Heiß diskutierte Inhalte
Router & Routing
Zwei Netzwerke erstellen
Frage von bunteblumeRouter & Routing14 Kommentare

Hallo Zusammen, Ich möchte gerne ein backup von einem bestimmten Folder welcher auf dem Server regelmässig synchronisiert wird auf ...

Linux
Limux-Ende in München: Wie ein Linux Projekt unter Ausschluss der Öffentlichkeit zerstört wurde
Information von FrankLinux13 Kommentare

Mein persönlicher Kommentar zum Thema "Limux-Ende". Die SPD-Politikerin Anne Hübner hat die Richtung von München ganz klar definiert: "Wir ...

Windows 10
Alle Programme mit bestimmtem Namen automatisch (per GPO) deinstallieren
gelöst Frage von lordofremixesWindows 1012 Kommentare

Hallo zusammen, gibt es eine Möglichkeit, alle Programme beginnend mit z.B. "Dell" im Namen per Script und somit per ...

Off Topic
Fachkräftemangel in Deutschland? - Talentschmiede schreibt alle 2 Tage die gleichen Stellen aus
Frage von Penny.CilinOff Topic12 Kommentare

Hallo, haben wir in Deutschland Fachkräftemangel? Die Talentschmiede schreibt gefühlt alle zwei Tage dieselben Stellen aus. Und das schon ...