Heim > Datenbank > MySQL-Tutorial > Wie aktualisiere ich eine Oracle SQL-Tabelle mit Daten aus einer anderen Tabelle?

Wie aktualisiere ich eine Oracle SQL-Tabelle mit Daten aus einer anderen Tabelle?

Susan Sarandon
Freigeben: 2025-01-22 02:46:10
Original
478 Leute haben es durchsucht

How to Update an Oracle SQL Table with Data from Another Table?

Tabellendaten mit Oracle SQL aktualisieren

Beim Umgang mit relationalen Datenbanken wie Oracle SQL kann es vorkommen, dass Sie eine Tabelle mit Daten aus einer anderen Tabelle aktualisieren müssen. Diese Aufgabe wird normalerweise mit dem UPDATE-Befehl von SQL ausgeführt.

Frage:

Angenommen, es gibt zwei Tabellen, Tabelle 1 und Tabelle 2, die beide die Spalten „id“, „name“ und „desc“ enthalten, und Sie müssen die Daten in Tabelle 1 mit den entsprechenden Daten in Tabelle 2 basierend auf den übereinstimmenden ID-Werten aktualisieren. Das gewünschte Ergebnis ist, dass Tabelle 1 mit den Namens- und Desc-Werten aktualisiert werden sollte, die den ID-Werten in Tabelle 2 entsprechen.

Lösung:

Um dieses Update zu implementieren, können Sie das entsprechende Update in Oracle SQL verwenden. Das Folgende ist die detaillierte Methode:

<code class="language-sql">UPDATE table1 t1
SET (name, desc) = (SELECT t2.name, t2.desc
FROM table2 t2
WHERE t1.id = t2.id)
WHERE EXISTS (
SELECT 1
FROM table2 t2
WHERE t1.id = t2.id );</code>
Nach dem Login kopieren

Anleitung:

  • Der UPDATE-Befehl startet den Aktualisierungsvorgang für Tabelle 1 und gibt ihr den Alias ​​t1.
  • Die SET-Klausel gibt an, dass die Namens- und Desc-Spalten von Tabelle 1 mit den Werten aus Tabelle 2 aktualisiert werden.
  • Die Unterabfrage in der SET-Klausel ruft die entsprechenden Namens- und Desc-Werte für jede Zeile in Tabelle 1 aus Tabelle 2 (t2) ab.
  • Die WHERE-Klausel in der Unterabfrage stellt sicher, dass nur Zeilen mit übereinstimmenden ID-Werten aktualisiert werden.
  • Die äußere WHERE-Klausel prüft außerdem, ob es eine Zeile in Tabelle 2 gibt, die mit jeder Zeile in Tabelle 1 übereinstimmt. Dadurch wird sichergestellt, dass nur Zeilen mit gültigen Übereinstimmungen aktualisiert werden.

Alternativer Ansatz (vorausgesetzt, der Schlüssel behält die Ansicht):

Wenn die Verknüpfung zwischen Tabelle 1 und Tabelle 2 zu einer schlüsselerhaltenden Ansicht führt, können Sie auch die folgende Methode verwenden:

<code class="language-sql">UPDATE (SELECT t1.id, 
t1.name name1,
t1.desc desc1,
t2.name name2,
t2.desc desc2
FROM table1 t1,
table2 t2
WHERE t1.id = t2.id)
SET name1 = name2,
desc1 = desc2;</code>
Nach dem Login kopieren

Anleitung:

  • Diese Methode geht davon aus, dass die schlüsselerhaltende Ansicht als Zwischenschritt erstellt wurde.
  • Der erste Teil ist eine Unterabfrage, die eine Verknüpfung zwischen Tabelle 1 und Tabelle 2 durchführt.
  • Wenn Sie die Ansicht basierend auf dem Schlüssel beibehalten, können Sie die Namens- und Desc-Spalten von Tabelle 1 direkt mit den Werten in der Zwischenansicht aktualisieren.

Das obige ist der detaillierte Inhalt vonWie aktualisiere ich eine Oracle SQL-Tabelle mit Daten aus einer anderen Tabelle?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage